草庐IT

Async-await

全部标签

c# - LINQ 代码中的异步 - 说明?

几乎每个SO关于此主题的回答都指出:LINQdoesn'tworkperfectlywithasync还有:Irecommendthatyounotthinkofthisas"usingasyncwithinLINQ"但在Stephen的书中有一个示例:Problem:Youhaveacollectionoftaskstoawait,andyouwanttodosomeprocessingoneachtaskafteritcompletes.However,youwanttodotheprocessingforeachoneassoonasitcompletes,notwaitingf

async 和 await 原来这么简单

前言前端同学们可能都知道async和await的使用,当被面试官问到async和await的是什么?或者说一说你对async、await的理解?如果我们还是仅仅去阐述我是如何使用的就显得格外的苍白无力。今天博主就来带大家进一步认识我们的async和await。首先来说由于浏览器/引擎负责解释和执行JavaScript的主线程是单线程,同步执行一个耗时较大的任务会导致阻塞。异步执行代码就是来解决阻塞问题,但会带来顺序的不确定性(多个异步执行过程的不确定性)回调函数如果说这些异步之间不会相互依赖或者不会因为顺序不确定收到影响是么有关系的,但是如果我们一些逻辑需要依赖某个异步的返回值那么这个时候我们

c# - 为什么在 finally block 中不允许等待?

为什么await不允许出现在finallyblock中?publicasyncvoidFn(){try{}finally{awaitTask.Delay(4000);}}知道可以手动获取AwaiterpublicvoidFn(){try{}finally{varawaiter=Task.Delay(4000).GetAwaiter();}} 最佳答案 取自:Wherecan’tIuse“await”?Insideofacatchorfinallyblock.Youcanuse“await”insideofatryblock,rega

c# - 使用 Async 和 Await 进行异步编程

我正在浏览有关如何在C#中进行异步编程的教程,但遇到了一个我不确定如何解决的错误。这是链接:http://msdn.microsoft.com/en-us/library/hh191443.aspx错误是:Cannotfindalltypesrequiredbythe'async'modifier.Areyoutargetingthewrongframeworkversion,ormissingareferencetoanassembly?我的目标是.NET4.0框架,但不确定是否需要任何其他程序集。代码如下:publicasyncTaskAccessTheWebAsync(Class

c# - Task.WhenAll() - 它会创建一个新线程吗?

根据MSDN:Createsataskthatwillcompletewhenallofthesuppliedtaskshavecompleted.当调用Task.WhenAll()时,它会创建一个任务,但这是否一定意味着它会创建一个新线程来执行该任务?例如,下面这个控制台应用程序中创建了多少个线程?classProgram{staticvoidMain(string[]args){RunAsync();Console.ReadKey();}publicstaticasyncTaskRunAsync(){Stopwatchsw=newStopwatch();sw.Start();Tas

c# - 使用 "return"终止或退出 C# 异步方法

我是C#5.0中的async-await方法的新手,我脑子里的问题很少如果async方法未通过输入参数或null检查,最好的转义方法是什么?在Taskasync方法中使用return;的逻辑流程是什么(在某些情况下,它变成了无限循环)?CancellationToken或Task.Yield是否更适合这种情况?publicFuncUploadSuccessCallBackAsync{get;set;}privateasyncTaskOnUploadSuccessAsync(AzureBlobInfoinfo){if(this.UploadSuccessCallBackAsync==nu

c# - 它有什么区别 - 使用 Task.Run 运行 'async' Action 委托(delegate)(与默认 Action 委托(delegate)相比)?

我正在努力了解async/await并认为我确实了解有关用法的一些事情。但仍然不太清楚在下面的场景中实际好处是什么。查看Task.Run用法。第一种方法使用普通委托(delegate)并使用Thread.Sleep,但第二种方法使用“异步”委托(delegate)和Task.Delay。我的问题是:这对这个方法有什么影响(或没有影响)?该方法本身是一个异步方法。该代码正在创建一个单独的线程(通过Task.Run),并且该线程除了执行该委托(delegate)之外别无他法。因此,即使它在Task.Delay上产生等待,在这种情况下有什么用,因为线程无论如何都是一个孤立的线程,不用于任何其

c# - 为什么运行一百个异步任务比运行一百个线程花费的时间更长?

为什么运行一百个异步任务比运行一百个线程花费的时间更长?我有以下测试类:publicclassAsyncTests{publicvoidTestMethod1(){vartasks=newList();for(vari=0;i();for(vari=0;iLongRunningOperationAsync(){varsw=Stopwatch.StartNew();awaitTask.Delay(500);Debug.WriteLine("Completedat{0},took{1}ms",DateTime.Now,sw.Elapsed.TotalMilliseconds);return

c# - 将同步方法变成异步方法

我正在尝试将一些旧代码的同步方法转换为异步方法,但我在理解时遇到了一些麻烦。从我读过的所有视频和教程来看,他们似乎正在创建两种方法:一种是实际功能,另一种是包装器,然后是在UI上调用的包装器。这是我的代码:privateasyncTasklogin(Stringusername,Stringpassword){vartcs=newTaskCompletionSource();RestSharp.RestRequestrequest=newRestSharp.RestRequest("/accounts/login/",RestSharp.Method.GET);RestSharp.IR

c# - 异步任务和锁

我有一个应该由两个进程更新的元素列表。第一个是UI线程(由用户控制),第二个是从Web服务检索信息的后台进程。由于第二个进程是I/O绑定(bind)的,它似乎适合异步任务。这引出了几个问题:由于异步任务不在单独的线程上运行,看来我在更新此列表时不需要任何类型的锁,对吧?另一方面,我们是否可以假设异步任务永远不会在单独的线程上运行?我说的是Windows窗体应用程序。也许将来我希望它作为控制台应用程序运行。AFAIK,在控制台应用程序中,异步任务在单独的线程上运行。如果任务在单独的线程上运行,询问任务的首选习惯用法是什么?这样我就可以在必要时建立锁。我不知道我是否真的需要一把锁,这让我想