编程定义:究竟是什么'建筑'。

时间:2009-10-25 23:46:04

标签: build build-process build-automation definition

构建 解决方案/项目/计划意味着什么?我想确保我的定义是正确的(所以我在谈话时听起来不像个白痴)。在IDE中,你可以(纠正我,如果我错了)编译源代码/编程代码到计算机可读的机器代码中。您可以调试一个程序,它基本上是通过程序逐步执行并查找错误。

但是 构建 一个程序究竟做了什么?在VS中,我知道在构建程序时,它会在调试文件夹中生成可执行文件。

任何关于 构建 程序意味着什么的核心技术定义?

4 个答案:

答案 0 :(得分:49)

构建对许多人来说意味着很多东西,但一般来说,这意味着从开发人员生成的源文件开始,然后以可以部署的安装包结束

“构建”可以包含很多内容:

  • 源文件的编译(适用于支持单独/显式编译步骤的语言/环境)
  • 链接目标代码(适用于支持单独/显式链接步骤的语言/环境)
  • 制作分发包,也称为“安装程序”
  • 生成嵌入在源代码文件中的文档,例如Doxygen,Javadoc
  • 执行自动化测试,如单元测试,静态分析测试和性能测试
  • 生成报告,告诉开发团队在构建期间发生了多少警告和错误
  • 部署分发包。例如,构建可以自动部署/发布新版本的Web应用程序(假设构建成功)。

“构建”可以“手动”完成,也可以自动完成,也可以是两者的混合。手动构建是一种构建,需要逐个执行编译器之类的构建命令。自动构建将所有单独的构建工具打包到一个大型构建程序中,该程序可以(理想情况下)在一个步骤中运行。

答案 1 :(得分:8)

这意味着将人类可读的源工件转换为机器可读的工件的过程。

答案 2 :(得分:5)

许多项目涉及大量源文件。 原则上,您可以手动编译这些文件中的任何一个 - 您使用编译器将该源文件编译为包含机器代码的(临时)目标文件。

实际上,一次一个地手动编译每个源文件太繁琐了, 甚至更乏味地手动跟踪需要重新编译的源文件。 因此,我们通过运行自动构建程序(通常称为“make”)立即构建整个项目。 该程序通过一个源文件列表,通常存储在另一个名为“makefile”的“源”文件中,并在每个文件上调用编译器 - 许多版本的“make”足够智能,只能重新编译已更改的文件所以需要重新编译。

虽然编译可以说是构建过程中最重要的部分,但编译后通常“构建”会运行许多其他程序。有时,完整的构建将花费更多的时间来运行这些其他程序,而不是运行编译器。

例如,许多人发现使用单个按钮不仅可以将所有源代码编译为最新版本,还可以运行一系列标准测试(C2: One Button Testing)。 因此,makefile还列出了运行这些测试所需的任何命令,这些命令将成为构建过程的一部分。

答案 3 :(得分:4)

这并不一定与人类对“构建”的意义有关,但就MSBuild 2.0而言,Microsoft.Common.targets中的代码如此描述:

...
<!--
============================================================
                                    Build

The main build entry point.
============================================================
-->
<PropertyGroup>
    <BuildDependsOn>
        BeforeBuild;
        CoreBuild;
        AfterBuild
    </BuildDependsOn>
</PropertyGroup>
<Target
    Name="Build"
    Condition=" '$(_InvalidConfigurationWarning)' != 'true' "
    DependsOnTargets="$(BuildDependsOn)"
    Outputs="$(TargetPath)"/>

<!--
============================================================
                                    BeforeBuild

Redefine this target in your project in order to run tasks just before Build
============================================================
-->
<Target Name="BeforeBuild"/>

<!--
============================================================
                                    AfterBuild

Redefine this target in your project in order to run tasks just after Build 
============================================================
-->
<Target Name="AfterBuild"/>

<!--
============================================================
                                    CoreBuild

The core build step calls each of the build targets.
============================================================
-->
<PropertyGroup>
    <CoreBuildDependsOn>
          BuildOnlySettings;
          PrepareForBuild;
          PreBuildEvent;
          UnmanagedUnregistration;
          ResolveReferences;
          PrepareResources;
          ResolveKeySource;
          Compile;
          GenerateSerializationAssemblies;
          CreateSatelliteAssemblies;
          GenerateManifests;
          GetTargetPath;
          PrepareForRun;
          UnmanagedRegistration;
          IncrementalClean;
          PostBuildEvent
    </CoreBuildDependsOn>
</PropertyGroup>
<Target
    Name="CoreBuild"
    DependsOnTargets="$(CoreBuildDependsOn)">

    <OnError ExecuteTargets="_TimeStampAfterCompile;PostBuildEvent" Condition="'$(RunPostBuildEvent)'=='Always' or '$(RunPostBuildEvent)'=='OnOutputUpdated'"/>
    <OnError ExecuteTargets="_CleanRecordFileWrites"/>

</Target>
...

这表明'build'大致意味着“编译加上所有相关的辅助事件,这些事件可以帮助您从代码工件到可部署的结果”。