我已经到了可以在Visual 2019中重复构建并具有确定性构建的地步.在使用MSBuild v16在命令行上构建时也是如此。不幸的是,使用VS2019生成时输出的程序集与使用MSBuild构建时的程序集不同。
我理解确定性构建过程的概念,以及编译器在做出选择时考虑到的众多因素。我需要做的是准确地找出Visual在编译过程中所做的事情,以便我可以使用MSBuild进行复制。据我所见,Visual绕过MSBuild直接进入编译器(这不会使这件事变得更容易)。
有没有人尝试过这样做,并且成功了?也许你尝试过却放弃了?两者的答案同样有帮助。
提前谢谢。
发布于 2020-05-05 07:35:45
如何确定地使用Visual和MSBuild进行构建?
实际上是,用于构建C#项目,VS IDE调用MSBuild来构建项目。VS调用MSBuild构建项目,该项目本身与通过命令行编译的MSBuild一致。MSBuild存在于C:\Program Files (x86)\Microsoft Visual Studio\2019\xxxx\MSBuild\Current\Bin下的VS2019文件夹中。
只是VS集成了很多工具。如果您在VS IDE中安装了一些与构建相关的扩展或工具,它可能会影响最终的构建。MSBuild(命令行)是一个纯粹的编译工具,VS IDE将调用它来构建。
---------------------------
First,我想知道您是否使用VS IDE和它的Developer命令提示VS(存在于VS2019 IDE下)分别构建项目。如果是这样的话,我认为您应该确保命令行参数与VS中的构建参数是否一致。
首先,请禁用Extensions-->Manage扩展下的任何第三方扩展,以防它们影响VS中的MSBuild。
然后,确保在构建项目时,应该注意每个项目的Configuration(Debug或Release或Platform(x64,x86或Any CPU)。
然后,您应该在MSBuild命令行中这样做:
msbuild xxxx.csproj -t:build -p:Configuration=xxx -p:Platform=xxx确保生成指令是一致的。
--------------------------
第二个,当您在另一个代理中使用用于VS2019的构建工具时(它可以单独安装而不需要VS ),如果可以的话,您应该确保它的版本与VS相同。(构建工具版本v16.xxx与VS版本v16.xxx相同),不同版本的MSBuild将有稍微不同的构建,所以要保持一致。
实际上是,MSBuild使用csc.exe构建c#项目来编译文件,因此VS和MSBuild对于c#文件都是一致的。使用csc的不同编译器没有问题。
除了之外,要查看更多内容,可以这样查看详细的构建日志:
在和IDE中
Tools-->Options-->Projects and Solutions-->Build and Run-->set MSBuild project build output verbosity to Detailed。
在MSBuild
msbuild xxxx.csproj -t:build -p:Configuration=xxx -p:Platform=xxx -v:detailedhttps://stackoverflow.com/questions/61572527
复制相似问题