草庐IT

Async-await

全部标签

c# - 等待最后一次时不必要的异步/等待?

我最近一直在处理asyncawait(阅读所有可能的文章,包括Stephen和Jon的最后两章),但我已经得出结论,但我不知道它是否是100%正确。-因此我的问题。因为async只允许出现await这个词,所以我将把async放在一边。AFAIU,等待就是延续。与其编写功能性(连续)代码,不如编写同步代码。(我喜欢将其称为可回调代码)因此,当编译器到达await时-它会将代码拆分为2个部分,并注册第二部分以在第一部分完成后执行(我不知道为什么这个词未使用callback-这正是完成的操作)。(同时工作-线程回来做其他事情)。但是看看这段代码:publicasyncTaskProcess

c# - 异步 CTP - 如何使用异步/等待调用 wcf 服务?

如果我调用WCF服务方法,我将执行如下操作:proxy.DoSomethingAsync();proxy.DoSomethingAsyncCompleted+=OnDoSomethingAsyncCompleted;我如何使用新的async做同样的事情?CTP?我想我需要类似proxy.DoSomethingTaskAsync的东西或proxy.DoSomethingAsync().ToTask()?Web服务调用需要返回Task能够使用await关键字,但如何?? 最佳答案 在CTP中,有一些工厂方法可以将常规APM函数(开始/结

c# - 为什么任务甚至在等待中完成

我在下面的代码中遇到问题:staticvoidMain(string[]args){TasknewTask=Task.Factory.StartNew(MainTask);newTask.ContinueWith((TasksomeTask)=>{Console.WriteLine("MainState="+someTask.Status.ToString()+"IsFaulted="+someTask.IsFaulted+"isComplete="+someTask.IsCompleted);});while(true){}}staticasyncTaskMainTask(){Con

c# - 从 TaskCompletionSource 返回 Task 而不是 Task<TResult>

正如我在几个codingexamples中看到的那样,以及我从这个SOquestion中可以理解的内容我应该能够从TaskCompletionSource返回一个非通用任务(i.e.,ReturnTaskandnotTaskfromthemethodUploadFilesAsync)还有下面的代码:publicasyncTaskUploadFilesAsync(stringfileAPath,stringfileBPath){vartcs=newTaskCompletionSource();//logictoprocessfilestry{awaitTask.WhenAll(uploa

c# - HttpClient 上的 ObjectDisposedException

我有一个带有多个API调用的Windows通用项目。一种方法拒绝工作,即使我的其他调用像这样完美地工作。我已经尝试使用using关键字,认为它可以解决问题。函数:publicasyncTaskGetNewUser(stringuser_guid,OAuthTokensOAuth){StringuserguidJSON=VALIDJSON_BELIEVE_ME;using(varhttpClient=newHttpClient()){httpClient.DefaultRequestHeaders.Accept.Add(newMediaTypeWithQualityHeaderValue

c# - 如何结合 TaskCompletionSource 和 CancellationTokenSource?

我有这样的代码(此处已简化)等待完成任务:vartask_completion_source=newTaskCompletionSource();observable.Subscribe(b=>{if(b)task_completion_source.SetResult(true);});awaittask_completion_source.Task;想法是订阅并等待bool值流中的true。这完成了“任务”,我可以继续超越await。但是我想取消--但不是订阅,而是等待。我想将取消token(以某种方式)传递给task_completion_source,因此当我取消token源时

c# - 带有异步 lambda 和 Task.WaitAll 的 Task.Factory.StartNew

我正在尝试对任务列表使用Task.WaitAll。问题是任务是一个异步lambda,它会破坏Tasks.WaitAll,因为它从不等待。这是一个示例代码块:Listtasks=newList();tasks.Add(Task.Factory.StartNew(async()=>{using(dbContext=newDatabaseContext()){varrecords=awaitdbContext.Where(r=>r.Id=100).ToListAsync();//dolongcpuprocesshere...}}Task.WaitAll(tasks);//domorestuf

c# - 在 C# 中启动许多异步任务的语法

我在使用C#中的新异步/等待工具时遇到问题。这是我的场景:staticasyncTaskManageSomeRemoteTask(intId,boolflag){varresult=awaitserviceClient.AuthenticateIdAsync(Id);[...SetupSomeData...]awaitserviceClient.LongAndSlowRemoteCallAsync(Data);}staticvoidSendATonOfJunkToSomeWebServiceThatDoesntSupportBatches{varmyTasks=Dictionary>(

c# - async await是否增加上下文切换

我知道异步等待的工作原理。我知道当执行到达等待时,它释放线程并在IO完成后,它从线程池中获取线程并运行剩余的代码。这样可以有效地利用线程。但我在某些用例中感到困惑:我们应该为非常快速的IO方法使用异步方法,比如缓存读/写方法吗?它们不会导致不必要的上下文切换吗?如果我们使用sync方法,执行将在同一个线程上完成,并且可能不会发生上下文切换。Async-await是否仅节省内存消耗(通过创建较少的线程)。或者它也可以节省cpu?据我所知,在同步IO的情况下,当IO发生时,线程进入休眠模式。这意味着它不消耗cpu。这种理解是否正确? 最佳答案

c# - "Async All the Way Down": Well, 底部到底是什么?

关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭5年前。Improvethisquestion我正在尝试完全理解async-await,而我的理解中的差距之一是了解什么是“AlltheWayDown”。我创建了一个async方法,它被另一个async方法调用,等等,一直到我用模糊的术语理解的东西,比如“UI”或“一个可以处理多个请求的网络服务器”。我如何用技术术语描述什么是“一直向下”?让我们以网络服务器的第二个例子为例。假设我有一个像这样的Controller操作[HttpGet]pub