gpt4 book ai didi

c# - Metro 应用程序中的异步调用链接

转载 作者:行者123 更新时间:2023-11-30 21:07:45 24 4
gpt4 key购买 nike

我是 Metro 开发人员的新手,我只希望能够以一种可以理解的方式表达我的问题......

实际上,我正在将旧应用程序的一部分移植到 Metro。逻辑部分是一个单独的项目(可移植库),它应该服务于 1) 旧的 WPF 应用程序和 2) 新的 Metro 应用程序。基本逻辑是相同的,但某些子系统(例如文件操作管理器)必须以不同方式编码 - 即 Metro 的异步方式。

我的问题是:我是否必须将整个调用方-被调用方方法链重写为新的异步范例?假设我有 4 个方法链,从方法 A = Metro UI 事件异步处理程序开始(对我来说将它编码为 async void 是有意义的,因为它是最重要的 fire&forget 事件),通过接下来的 2 个方法(B 和 C ) 放置在我的应用程序的不同层中,一直到包含“await CreateFileAsync”方法(由 Microsoft 制作的异步)的方法 D。

现在:应该使用 await 调用异步 CreateFileAsync 方法。这迫使我也使方法 D 异步。要从 C 调用方法 D,从 B 调用 C,从 A 调用 B - 我是否必须将所有 A、B 和 C 重写为异步等待样式?

我能感觉到我缺少更深层次的知识,所以我正在努力自学,但同时我想在这里碰碰运气...

我必须重写大部分代码吗?我上面的任何陈述都是错误的吗?

提前致谢,汉斯

最佳答案

我建议您将可移植库重写为异步的。它不像以前那么糟糕; Microsoft 在 async/await 方面下了很多功夫,以尽可能轻松地将同步代码转换为异步代码。我预计在不久的将来会有很多其他人做同样的事情,并且 R# 可能会实现“make async”重写。

混契约(Contract)步和异步代码时存在不明显的陷阱 - 请参阅 Stephen Toub 的上一篇博文 Should I expose synchronous wrappers for asynchronous methods?出于这个原因,我认为将异步操作公开为异步 API(以及将同步操作公开为同步 API)会更简洁。

更新:如果您确实希望同步代码调用异步代码,那么您可以使用my AsyncEx library 中的Task.WaitAndUnwrapException 扩展方法。 .但是,您仍然遇到 Stephen Toub 的帖子中提到的问题,即:

  1. 如果您的库没有尽可能地使用 ConfigureAwait(false),您可能会死锁。
  2. 如果您遇到线程池中的最大线程数,您也可能会死锁。

(2) 不再那么普遍了,但 (1) 是一个真正的可能性。经常是brought up由刚刚测试 async 的人将其与同步代码混合。

关于c# - Metro 应用程序中的异步调用链接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10183179/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com