- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我无法得到关于这个问题的明确答案,所以这个问题。过去很少有 SO 帖子提到 HashAlgorithm
的实例在 MSDN 文档中不是线程安全的引用片段。
见
但是,current MSDN doc没有这么说。令人惊讶的是,下面的代码不会在 net3.1、net5.0 上爆炸,但在 net6.0 上会。所以,看起来它是线程安全的(也许),但也许 net6.0 有一个错误。
//<TargetFrameworks>net6.0;net5.0;netcoreapp3.1;net48</TargetFrameworks>
[Explicit]
[Test]
public void Bork_HashAlgorithm()
{
const int iterations = 1_000_000;
var bytes = Encoding.UTF8.GetBytes("the overtinkerer");
using (var md5 = MD5.Create())
{
Parallel.For(0, iterations, (i, loop) =>
{
md5.ComputeHash(bytes);
});
}
}
异常信息:
SafeHandle cannot be null. (Parameter 'pHandle')
最佳答案
不,它不是线程安全的。
我们在峰值负载下看到了相同的异常:SafeHandle 不能为 null。 (参数“pHandle”)
以及 MD5 提供程序、SHA1 和 SHA256 的类似错误,到处都是。
但是我们发现使用带有锁
的HashAlgorithm
的“单例”实例仍然是有益的,它仍然比每次创建一个单独的实例快 3 倍时间。
这是基准
代码如下:
static MD5 _md5 = MD5.Create(); // <-- one instance for all threads
public static byte[] MD5Hash(byte[] input)
{
lock (_md5) // <-- use a lock
{
return _md5.ComputeHash(input);
}
}
更新:我还对 .NET 5 中引入的新静态 MD5.HashData
方法进行了基准测试——它并不比使用 lock
快。然而,MD5.HashData
在重度并行性下表现出更好的性能,这是 BDN 无法模拟的(参见下面的评论)
更新 2:添加 SHA256 基准
警告:
请注意有关并行度的评论 here .
关于c# - HashAlgorithm.ComputeHash() 是线程安全的吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/73006466/
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
我有 2 个相同的图像,具有不同的图像属性和文件属性(例如 CreationDate 等)。当我计算哈希值时,我得到不同的哈希值。有没有办法跳过这些属性并计算哈希值以获得相同的哈希值? 等待帮助。谢谢
为什么下面两种调用ComputeHash的方法结果长度不同?看起来代码应该产生相同的结果。 byte[] KeyBytes = Convert.FromBase64String("KgMLuq+k1o
我无法得到关于这个问题的明确答案,所以这个问题。过去很少有 SO 帖子提到 HashAlgorithm 的实例在 MSDN 文档中不是线程安全的引用片段。 见 Why does SHA1.Comput
我试图弄清楚如果机器键值不同,已散列的值(使用下面的代码)是否会不同。另外,我想知道其他语言(即 Java)的实现是否会产生不同的结果。 string hashedPassword = Convert
我有一个简单的代码来为文件生成校验和来比较文件是否是新的。 class Program { static void Main(string[] args) { usin
我正在使用 C# 代码: using (var md5 = MD5.Create()) { using (var fStream = File.OpenRead(fFile)) {
我遇到了一个有趣的问题。似乎“HMACSHA256”散列的 ComputeHash() 的行为不是确定性的。如果我使用 HashAlgorithm.Create(“HMACSHA256”) 创建两个
我需要独立计算多个数据 block 的哈希值。像这样: using( HashAlgorithm hasher = new ActualHashAlgorithm() ) { for( int
背景(您可以跳过此部分) 我有大量数据(大约 3 MB)需要在数百台机器上保持最新。一些机器运行 C#,一些运行 Java。数据可能随时更改,需要在几分钟内传播给客户端。数据以 Json 格式从 4
我在问自己,在 asp.net 页面的代码隐藏上使用包含 HMACSHA1 实例的静态(共享)变量是否会很危险。问题在于,在同一个 asp.net 页面上处理多个同时请求时,所有 asp.net 工作
我看不出有什么方法可以对 MD5.ComputeHash(Stream) 加盐。我是否缺少将字节注入(inject) HashAlgorithm 的某种方法? 我尝试在执行流计算之前执行 Comput
我通过以下方式在 C# 中计算字符串的 MD5 哈希值: var provider = new System.Security.Cryptography.MD5CryptoServiceProvide
我发现我维护的一些代码存在问题。下面的代码有一个 private static SHA1 成员(它是一个 IDisposable 但因为它是 static,所以它永远不会被最终确定)。然而,在压力下,
我在使用 computeHash 时遇到了一些麻烦。我同时使用computeHash(Stream) 和computeHash(byte[])。出于某种原因,他们正在回馈不同的结果。我试过将 byte
我通过下面的代码定期计算文件的 MD5 哈希值。这些文件大约有 10MB。当我在 Debug模式(调试 | x64)下运行我的程序时,对 ComputeHash() 的调用需要 35 毫秒,如果在 R
我正在使用以下代码对工作正常的文件执行校验和。但是,当我为一个大文件(比如 2 GB)生成哈希时,速度非常慢。我怎样才能提高这段代码的性能? fs = new FileStream(txtFile.T
我收到 ObjectDisposedException:安全句柄已关闭。 这是我的代码: 我正在尝试创建一个接口(interface)和实现类,这将使我能够获取一个字符串,将一个已知 key 附加到它
有人可以向我解释为什么不使用 T-SQL SELECT substring(master.dbo.fn_varbintohexstr(hashbytes('MD5', 'HelloWorld')),
我正在寻找计算大文件 (3GB) 哈希值的有效方法,并意识到使用参数 -hashfile 调用 Windows certutil 执行哈希计算比通过 执行哈希计算快 4 倍(16 秒) code>SH
我是一名优秀的程序员,十分优秀!