"Wrong assembly binding redirects" 当 运行 BenchmarkDotNet

"Wrong assembly binding redirects" when running BenchmarkDotNet

当 运行 BenchmarkDotNet 用于我的项目中的方法时,我得到一些 "Wrong assembly binding redirect" warning/error 消息打印到屏幕上。这让我有点困惑,因为我认为程序集绑定重定向是一个 .Net Framework 概念,而我的项目是 .Net Core 3.0。谷歌搜索 warning/error 消息没有结果。有关这些消息含义以及可能如何解决问题的任何提示。我尝试清理 Nuget 缓存、恢复 Nuget 包、清理和重建解决方案,但没有任何帮助。

// BeforeAnythingElse

// Benchmark Process Environment Information:
// Runtime=.NET Core 3.0.0 (CoreCLR 4.700.19.46205, CoreFX 4.700.19.46214), X64 RyuJIT
// GC=Concurrent Workstation
// Job: DefaultJob

OverheadJitting  1: 1 op, 308100.00 ns, 308.1000 us/op
// Wrong assembly binding redirects for System.Data.Common.resources, Version=4.2.1.0, Culture=en-US, PublicKeyToken=b03f5f7f11d50a3a.
// Wrong assembly binding redirects for System.Data.Common.resources, Version=4.2.1.0, Culture=en, PublicKeyToken=b03f5f7f11d50a3a.
// Wrong assembly binding redirects for System.Data.SqlClient.resources, Version=4.6.0.0, Culture=en-US, PublicKeyToken=b03f5f7f11d50a3a.
// Wrong assembly binding redirects for System.Data.SqlClient.resources, Version=4.6.0.0, Culture=en, PublicKeyToken=b03f5f7f11d50a3a.
// Wrong assembly binding redirects for System.Private.Xml.resources, Version=4.0.1.0, Culture=en-US, PublicKeyToken=cc7b13ffcd2ddd51.
// Wrong assembly binding redirects for System.Private.Xml.resources, Version=4.0.1.0, Culture=en, PublicKeyToken=cc7b13ffcd2ddd51.

简短的回答是您可以忽略此警告。

长答案:出于某种原因,VS 有时会为引用 .NET Standard 库的完整 .NET Framework 项目生成无效的程序集绑定重定向。过去给 BenchmarkDotNet 用户带来了很多麻烦:

我决定实施一个丑陋的解决方法,即手动搜索 .dll 文件并在 .NET Framework 失败时加载它。

当然,这仅适用于完整的 .NET Framework。当我将 BenchmarkDotNet 移植到 .NET Standard 2.0 时,我忘记了我们不需要为 .NET Core 执行此操作。作为最终结果,您会收到这个令人困惑的警告。

我已发送修复该问题的 PR:https://github.com/dotnet/BenchmarkDotNet/pull/1365 并且此解决方法现在将仅针对完整的 .NET Framework 项目执行