- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的构建过程运行良好,但对于一个非常小的项目来说需要将近 3 秒。
我怎样才能加快构建过程?
日志文件太大,无法发布。请随意询问有关记录器输出的问题,然后我会发布请求的部分。
构建项目的 C# 方法
private void CompileCode()
{
using (var buildManager = new BuildManager())
{
var result = buildManager.Build(this.CreateBuildParameters(), this.CreateBuildRequest());
if (result.OverallResult == BuildResultCode.Failure)
{
// Error handling
var stringbuilder = new StringBuilder();
using (var reader = new StreamReader(NameDebuggerLogFile))
{
stringbuilder.Append(reader.ReadToEnd());
}
throw new CompilerException(stringbuilder.ToString());
}
}
}
private BuildParameters CreateBuildParameters()
{
var projectCollection = new ProjectCollection();
var buildLogger = new FileLogger { Verbosity = LoggerVerbosity.Detailed, Parameters = "logfile=" + NameDebuggerLogFile };
var buildParameters = new BuildParameters(projectCollection) { Loggers = new List<ILogger>() { buildLogger } };
return buildParameters;
}
private BuildRequestData CreateBuildRequest()
{
var globalProperties = new Dictionary<string, string>();
var buildRequest = new BuildRequestData(FolderPath + NameProjectFile, globalProperties, null, new[] { "Build" }, null, BuildRequestDataFlags.ReplaceExistingProjectInstance);
return buildRequest;
}
用于构建过程的项目文件
<?xml version="1.0" encoding="utf-8"?>
<Project ToolsVersion="4.0" DefaultTargets="Build" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<Import Project="$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props" Condition="Exists('$(MSBuildExtensionsPath)\$(MSBuildToolsVersion)\Microsoft.Common.props')" />
<PropertyGroup>
<AssemblyName>GeneratedFlexForm</AssemblyName>
<OutputPath>DLL</OutputPath>
<OutputType>Library</OutputType>
<DebugType>none</DebugType>
<DebugSymbols>false</DebugSymbols>
<Optimize>false</Optimize>
</PropertyGroup>
<ItemGroup>
<Reference Include="System" />
<Reference Include="System.Xml" />
<Reference Include="System.Xml.Linq" />
<Reference Include="System.ServiceModel" />
<Reference Include="System.Runtime.Serialization" />
<Reference Include="System.Web" />
<Reference Include="System.Web.Services" />
<Reference Include="System.Drawing" />
<Reference Include="System.Design" />
<Reference Include="System.Data" />
<Reference Include="System.Core" />
<Reference Include="System.Management" />
<Reference Include="System.Configuration" />
<Reference Include="System.Xaml">
<RequiredTargetFramework>4.0</RequiredTargetFramework>
</Reference>
<Reference Include="WindowsBase" />
<Reference Include="PresentationCore" />
<Reference Include="PresentationFramework" />
<!--<Reference Include="FlexForms.Core" />-->
<Reference Include="FlexForms.Core, Version=1.0.0.0, Culture=neutral, processorArchitecture=MSIL">
<SpecificVersion>False</SpecificVersion>
<HintPath>Library\FlexForms.Core.dll</HintPath>
</Reference>
<Reference Include="Gizmox.WebGUI.Forms">
<SpecificVersion>False</SpecificVersion>
<HintPath>Library\Gizmox.WebGUI.Forms.dll</HintPath>
</Reference>
<Reference Include="Gizmox.WebGUI.Common">
<SpecificVersion>False</SpecificVersion>
<HintPath>Library\Gizmox.WebGUI.Common.dll</HintPath>
</Reference>
<Reference Include="FlexForms.ServiceProviders">
<SpecificVersion>False</SpecificVersion>
<HintPath>Library\FlexForms.ServiceProviders.dll</HintPath>
</Reference>
</ItemGroup>
<ItemGroup>
<Page Include="FlexForm.xaml">
<Generator>MSBuild:Compile</Generator>
<DependentUpon>RadioButtonValueConverter.cs</DependentUpon>
<SubType>Designer</SubType>
</Page>
<Compile Include="FlexForm.xaml.cs">
<DependentUpon>FlexForm.xaml</DependentUpon>
<SubType>Code</SubType>
</Compile>
<Compile Include="UserCode.cs">
<SubType>Code</SubType>
</Compile>
<Compile Include="RadioButtonValueConverter.cs">
<SubType>Code</SubType>
</Compile>
<Resource Include="datacontext.xml"/>
</ItemGroup>
<Import Project="$(MSBuildToolsPath)\Microsoft.CSharp.targets" />
</Project>
构建期间收集的记录器输出(由于文件大小,只有最后几行)
Done building project "projectfile.csproj".
Build succeeded. 0 Warning(s) 0 Error(s)
Time Elapsed 00:00:02.68
编辑:
我希望我可以在这里引用Seva Titov:
Building WPF is really tricky, for example XAML files get re-compiled twice (see MSDN). You cannot easily replicate it with just csc.exe. If you have XAML in your project, you have to use MSBuild. – Seva Titov
这就是我必须坚持使用 MSBuild 的原因。
无论如何,我有一些提高性能的想法:
问题 1:这是我的日志文件中的一个片段,它表示 MSBuild 将在解析依赖项时处理 .winmd、.dll 和 .exe 文件。
AllowedAssemblyExtensions:
.winmd
.dll
.exe
因为我只有 .dll 文件,所以我想禁用 MSBuild 考虑 .winmd 文件,这几乎适用于我所有的依赖项。 (下面的例子)
Primary reference "PresentationCore, Version=4.0.0.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35". Resolved file path is "C:\Program Files (x86)\Reference Assemblies\Microsoft\Framework.NETFramework\v4.0\PresentationCore.dll". Reference found at search path location "{TargetFrameworkDirectory}". For SearchPath "{TargetFrameworkDirectory}". Considered "C:\Program Files (x86)\Reference Assemblies\Microsoft\Framework.NETFramework\v4.0\PresentationCore.winmd", but it didn't exist.
解决方案:1我不得不修改我的 CreateBuildRequest() 方法:
private BuildRequestData CreateBuildRequest()
{
var globalProperties = new Dictionary<string, string>();
// Related to idea 1
globalProperties.Add("ExpandSDKAllowedReferenceExtensions", ".dll");
globalProperties.Add("AllowedReferenceAssemblyFileExtensions", ".dll");
globalProperties.Add("AllowedReferenceRelatedFileExtensions", string.Empty);
// Related to idea 2
globalProperties.Add("BuildProjectReferences", "false");
globalProperties.Add("BuildInParallel", "true");
var buildRequest = new BuildRequestData(FolderPath + NameProjectFile, globalProperties, "4.0", new[] { "Build" }, null, BuildRequestDataFlags.IgnoreExistingProjectState);
return buildRequest;
}
编辑 2:想法 2:有谁知道如何包含/maxcpucount 或/m 开关来并行构建我的项目?对此有解释MSDN page但我不知道如何将它应用到上面列出的项目文件中
解决方案 2:查看解决方案 1,但变化不大。
编辑 3:经过几个小时的玩耍,我想我将不得不放弃。我看到的唯一选择是总体上减少依赖性。但我稍后会回来讨论这个问题。
有点不相关:
> Task Performance Summary:
> 0 ms CreateItem 1 calls
> 0 ms AssignCulture 1 calls
> 0 ms CallTarget 2 calls
> 0 ms FindAppConfigFile 1 calls
> 0 ms Delete 4 calls
> 0 ms GetFrameworkPath 1 calls
> 0 ms ConvertToAbsolutePath 1 calls
> 0 ms MakeDir 1 calls
> 0 ms Message 5 calls
> 0 ms AssignTargetPath 6 calls
> 1 ms FindUnderPath 5 calls
> 1 ms FileClassifier 1 calls
> 1 ms RemoveDuplicates 2 calls
> 1 ms CreateCSharpManifestResourceName 1 calls
> 1 ms ReadLinesFromFile 1 calls
> 15 ms ResolveAssemblyReference 1 calls
> 21 ms ResourcesGenerator 1 calls
> 56 ms Copy 2 calls
> 299 ms GenerateTemporaryTargetAssembly 1 calls
> 502 ms Csc 2 calls
> 725 ms MarkupCompilePass1 1 calls
> 814 ms MarkupCompilePass2 1 calls
>
> Build succeeded.
> 0 Warning(s)
> 0 Error(s)
>
> Time Elapsed 00:00:02.27
最佳答案
要回答您的直接问题,您无能为力加快 msbuild 的速度。如果您的机器使用 SSD,我希望它运行得更快,但这可能不是您正在寻找的解决方案。
我唯一能想到的另一件事是完全停止使用 msbuild。它所做的只是驱动 C# 编译器。那么,为什么要费心使用 msbuild 呢?直接使用C#编译器即可。例如通过 CSharpCodeProvider
。
关于c# - 加快 MSBuild 构建过程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15658321/
我想使用 ffmpeg 框架更改视频速度。我为此使用了这个命令: ffmpeg -y -i /storage/extSdCard/Video/1.avi -filter_complex [0:v]fp
我有以下数据数组,有 200 万个条目: [20965 1239 296 231 -1 -1 20976 1239 299 314 147 337 255
我正在使用 Oracle 数据库,并且想获取一个包含 3000 万条记录的表。 library(RODBC) ch <- odbcConnect("test", uid="test_user",
我在 android 上使用 FFmpeg 来: 1- 合并 3 个视频 2-添加音频 3-添加标志 4-修剪 3 个视频之一 5-改变输出的fps 我已经实现了正确的代码,但花了 30 分钟。对于(
我使用 GLPKMathProgInterface 和 JuMP 编写了一个程序来解决 Julia 中的线性程序。 Julia 代码由 python 程序调用,该程序通过多个命令行调用运行多个 Jui
我们使用 POV-Ray 每次运行生成大约 80 张图像,我们将这些图像拼接在一起形成两个移动的 GIF 文件(一个场景的两个 360 度 View )。我们正在寻找尽可能加快此镜像创建的方法(在 h
就目前情况而言,这个问题不太适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、民意调查或扩展讨论。如果您觉得这个问题可以改进并可能重新开放,visit
我将数据从一个数据库插入到另一个数据库,所以我有 2 个连接(Conn1 和 Conn2)。下面是代码(使用pypyodbc)。 import pypyodbc Conn1_Query = "SE
在我的应用程序中,我显示 EKEvents 列表,我想在 UITableView 中显示一个月的所有事件,每个部分包含各自的日期。嗯,这可行,我得到了我需要的所有数据,但获取速度非常慢。 问题在于事件
我有一个移动速度非常慢的传送带。我不知道什么JS脚本控制速度,我需要它来加速。无法从主题制作者那里获得任何帮助。任何建议都会非常有帮助。谢谢 页面: http://krankgolf2017.wpen
有没有办法加快这段代码的速度?我需要它来删除相同的内容并将其写入单元格,以强制其他 VBA 代码运行另一列上的代码。这就是它的作用,只是 super 慢。有时此表上有 2000 个条目/行。每个单元大
我正在开发一个相当大的程序,它再次从一个相当大的 Excel 电子表格中获取数据。由于一些奇怪的原因,加载这个大的 Excel 文件需要很长时间,我希望能以某种方式加快速度。我做了自己的研究并尝试了
我有下面的代码,将所有按钮(有 10 个)着色为灰色,以清除任何先前着色的按钮,然后将所选按钮着色为蓝色。基本上充当当前选择哪个按钮的指示器。我注意到代码现在需要一些时间才能通过这种修饰添加来运行,我
我有一个 LINQ 查询,它正在搜索包含大约 250,000 条记录的 SQL 表,并且仅搜索 2 个字段。这两个字段都已建立索引,但我发现它的运行速度仍然相当慢。 下面是代码,有人可以提出任何建议来
对于相对较大的 Pandas DataFrame(几十万行),我想创建一个应用函数结果的系列。问题是该功能不是很快,我希望它能以某种方式加快速度。 df = pd.DataFrame({ 'valu
这个问题在这里已经有了答案: Faster weighted sampling without replacement (3 个答案) 关闭 9 年前。 如何在 R 中加快概率加权采样。 # Let
在运行 PhantomJS 提供的 rasterize.js 示例时,我发现我必须等待 20 秒或更长时间才能生成网页图像。 有没有可能在不消耗大量资源的情况下加快速度的方法?我基本上希望快速生成从加
我正在开发一个相当大的程序,它再次从一个相当大的 Excel 电子表格中获取数据。由于一些奇怪的原因,加载这个大的 Excel 文件需要很长时间,我希望能以某种方式加快速度。我做了自己的研究并尝试了
我有下面的代码,将所有按钮(有 10 个)着色为灰色,以清除任何先前着色的按钮,然后将所选按钮着色为蓝色。基本上充当当前选择哪个按钮的指示器。我注意到代码现在需要一些时间才能通过这种修饰添加来运行,我
我有一个 Excel 工作簿,用户通过单击按钮导入文本文件。我的代码完全按照我的需要工作,但是在填写 H 列“阅读日期”时速度非常慢。将文本文件导入 Excel 工作表后,我的 Excel 工作簿如下
我是一名优秀的程序员,十分优秀!