- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我已经看到很多关于编写代码的警告,例如...
public async void MyDangerousMethodWhichCouldCrashMyApp...
我读到过 Eventhandlers 没问题,因为它们必须返回 void。然而partial methods还必须返回 void。你可以有以下代码......
static void Main(string[] args)
{
MainAsync().Wait();
Console.ReadLine();
}
async static Task MainAsync()
{
MyCodeGeneratedClass c = new MyCodeGeneratedClass();
try
{
await c.MyCodeGeneratedMethod();
}
catch(Exception ex)
{
Console.WriteLine(ex.Message);
}
}
public partial class MyCodeGeneratedClass
{
public async Task MyCodeGeneratedMethod()
{
HttpClient client = new HttpClient();
Console.WriteLine(await client.GetStringAsync("http://msdn.microsoft.com"));
MyCustomCode();
}
partial void MyCustomCode();
}
然后实现为...
partial class MyCodeGeneratedClass
{
async partial void MyCustomCode()
{
HttpClient client = new HttpClient();
Console.WriteLine(await client.GetStringAsync("http://msdn.microsoft.com"));
throw new Exception("Boom");
}
}
但是如果 MyCustomCode 的实现遇到异常,应用程序会发生什么情况呢?
如果不行,考虑到 async/await 的流行程度,这是否意味着分部方法基本上已经过时了?代码生成系统是否应该停止公开部分方法以支持事件,或者最好还是在基类中清空 protected 虚拟方法?即
protected virtual Task MyCustomCode(T foo)
{
return Task.FromResult(0);
}
编辑:好的,所以我对代码进行了多次更新。在我写的原始伪代码没有得到好评之后。我认为上面的代码表明 async partial void MyPartialMethod 肯定存在问题,因为对 MyCodeGeneratedMethod 的调用似乎确实降低了应用程序域,尽管围绕调用进行了 try catch。我只是想知道是否有比转移到 protected 虚拟基类方法更好的选择。
最佳答案
But what will happen to the application if the implementation of MyCustomCode encounters an exception?
async void
方法的语义是直接在方法开始时的当前 SynchronizationContext
上引发异常。关于 async void
的这个和其他有趣的事实在我的 async
best practices 中有所介绍。文章。
does that mean partial methods are essentially obsolete?
与事件处理程序一样过时。所以,不,不是真的。但是,它们并未更新为允许 Task
的返回类型,因此它们似乎是一种语言功能,并未随语言的其余部分积极更新。
Should code generation systems stop exposing partial methods in favour of events or perhaps better still empty protected virtual methods in a base class?
事件根本不会改变这一点;它们仍将使用 async void
实现。
如果“钩子(Hook)”需要是异步的,那么这会改变所有生成的代码,因为它也必须都是异步的。
仅当生成的代码需要来自该部分方法的某些结果时,异步部分方法才会起作用并且实现必须执行一些异步工作才能生成该结果。根据我的经验,部分方法在概念上更像是事件,因此 async void
是可以接受的。
关于c# - async partial void MyPartialMethod() 危险吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39362143/
我有带皮肤的 DNN。我的 head 标签有 runat="server"所以我尝试在 head 标签内添加一个标签 "> 在后面的代码中,我在属性中设置了 var GoogleAPIkey。问题是它
我在 Node.JS 中有一个导出模块 exports.doSomethingImportant= function(req, res) { var id = req.params.id; Demo.
我是 F# 的新手,我一直在阅读 F# for Fun and Profit。在为什么使用 F#? 系列中,有一个 post描述异步代码。我遇到了 Async.StartChild函数,我不明白为什么
File 中有一堆相当方便的方法类,如 ReadAll***/WriteAll***/AppendAll***。 我遇到过很多情况,当我需要它们的异步对应物时,但它们根本不存在。 为什么?有什么陷阱吗
我最近开始做一个 Node 项目,并且一直在使用 async 库。我有点困惑哪个选项会更快。在某些数据上使用 async.map 并获取其结果,或使用 async.each 迭代一组用户并将他们的相应
您好,我正在试用 Springs 异步执行器,发现您可以使用 @Async。我想知道是否有可能在 @Async 中使用 @Async,要求是需要将任务委托(delegate)给 @Async 方法在第
我需要支持取消一个函数,该函数返回一个可以在启动后取消的对象。在我的例子中,requester 类位于我无法修改的第 3 方库中。 actor MyActor { ... func d
假设 asyncSendMsg不返回任何内容,我想在另一个异步块中启动它,但不等待它完成,这之间有什么区别: async { //(...async stuff...) for msg
我想用 Mocha 测试异步代码. 我跟着这个教程testing-promises-with-mocha .最后,它说最好的方法是 async/await。 以下是我的代码,我打算将 setTimeo
正如我有限(甚至错误)的理解,Async.StartImmediate 和 Async.RunSynchronously 在当前线程上启动异步计算。那么这两个功能究竟有什么区别呢?谁能帮忙解释一下?
我有一行使用await fetch() 的代码。我正在使用一些调用 eval("await fetch ...etc...") 的脚本注入(inject),但问题是 await 在执行时不会执行从ev
我正在尝试使用 nodeJS 构建一个网络抓取工具,它在网站的 HTML 中搜索图像,缓存图像源 URL,然后搜索最大尺寸的图像。 我遇到的问题是 deliverLargestImage() 在循环遍
我想结合使用 async.each 和 async.series,但得到了意想不到的结果。 async.each([1, 2], function(item, nloop) { async.s
我的代码有问题吗?我使用 async.eachSeries 但我的结果总是抛出 undefined。 这里是我的代码: async.eachSeries([1,2,3], function(data,
我想在 trait 中编写异步函数,但是因为 async fn in traits 还不被支持,我试图找到等效的方法接口(interface)。这是我在 Rust nightly (2019-01-0
async setMyPhotos() { const newPhotos = await Promise.all(newPhotoPromises); someOtherPromise();
async.js 中 async.each 与 async.every 的区别?似乎两者都相同,只是 async.every 返回结果。纠正我,我错了。 最佳答案 每个异步 .each(coll, i
我正在尝试对一组项目运行 async.each。 对于每个项目,我想运行一个 async.waterfall。请参阅下面的代码。 var ids = [1, 2]; async.each(ids,
我的目标是测试 API 调用,将延迟考虑在内。我的灵感来自 this post . 我设计了一个沙箱,其中模拟 API 需要 1000 毫秒来响应和更改全局变量 result 的值。测试检查 500
async.each 是否作为异步数组迭代工作? async.eachSeries 是否作为同步数组迭代工作?(它实际上等待响应) 我问这些是因为两者都有回调,但 async.each 的工作方式类似
我是一名优秀的程序员,十分优秀!