c# – 异步SHA256哈希

c# – 异步SHA256哈希,第1张

概述我有以下方法: public static string Sha256Hash(string input) { if(String.IsNullOrEmpty(input)) return String.Empty; using(HashAlgorithm algorithm = new SHA256CryptoServiceProvider()) { byte[] 我有以下方法:
public static string Sha256Hash(string input) {    if(String.IsNullOrEmpty(input)) return String.Empty;    using(HashAlgorithm algorithm = new SHA256CryptoServiceProvIDer()) {        byte[] inputBytes = EnCoding.UTF8.GetBytes(input);        byte[] hashBytes = algorithm.ComputeHash(inputBytes);        return BitConverter.ToString(hashBytes).Replace("-",String.Empty);    }}

有没有办法让它异步?我希望使用async和await关键字,但HashAlgorithm类不为此提供任何异步支持.

另一种方法是将所有逻辑封装在:

public static async string Sha256Hash(string input) {     return await Task.Run(() => {         //Hashing here...     });}

但这似乎并不干净,我不确定它是否是一种异步执行 *** 作的正确(或有效)方式.

我该怎么做才能做到这一点?

解决方法 您正在进行的工作本质上是同步cpu绑定工作.它本身并不是异步的,就像网络IO一样.如果你想在另一个线程中运行一些同步cpu绑定工作并异步等待它完成,那么Task.Run确实是完成它的正确工具,假设 *** 作足够长,需要异步执行它.

That said,there really isn’t any reason to expose an asynchronous wrapper over your synchronous method.通常同步公开方法更有意义,如果特定调用者需要它在另一个线程中异步运行,他们可以使用Task.Run明确指出对该特定调用的需要.

总结

以上是内存溢出为你收集整理的c# – 异步SHA256哈希全部内容,希望文章能够帮你解决c# – 异步SHA256哈希所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1241970.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-06
下一篇 2022-06-06

发表评论

登录后才能评论

评论列表(0条)

保存