草庐IT

async_wait

全部标签

c# - Thread.sleep vs Monitor.Wait vs RegisteredWaitHandle?

(以下项目有不同的目标,但我很想知道它们是如何“暂停”的)问题Thread.sleep-它会影响系统的性能吗?它会占用线程等待吗?Monitor.Wait呢?他们“等待”的方式有什么不同?他们会在等待时占用线程吗?RegisteredWaitHandle怎么样?此方法接受等待时执行的委托(delegate)句柄发出信号。在等待期间,它不会占用线程。所以一些线程被暂停并且可以被委托(delegate)唤醒,而其他线程只是等待?旋转?有人可以把事情说清楚吗?编辑http://www.albahari.com/threading/part2.aspx 最佳答案

c# - 为什么 void async 不好?

所以我理解为什么从async返回void通常是没有意义的,但我遇到过我认为它完全有效的情况。考虑以下人为的示例:protectedoverridevoidOnLoad(EventArgse){if(CustomTask==null)//Donotawaitanything,letOnLoadreturn.PrimeCustomTask();}privateTaskCompletionSourceCustomTask;//IDONOTcareaboutthereturnvaluefromthis.Sowhyisvoidbad?privateasyncvoidPrimeCustomTask

C# async/await - 限制调用异步方法/锁定的次数

我来自C++世界,所以我非常习惯锁定线程和互斥保护。假设这个基本功能:asyncTaskBasicProcess(){//awaittimeconsumingtask}如何锁定此函数,以便一次只能运行一个BasicProcess?这是我想要实现的:asyncTaskBasicProcess(){lock(BasicProcessLock){//awaittimeconsumingtask}} 最佳答案 你可以为此使用SemaphoreSlim(1),用(1)创建的SemaphoreSlim将确保只有一个线程可以获得锁,任何其他试图获

c# - 找不到类型或命名空间名称 'async'

在VS2012.2中,我有一个面向.NET4.5的ASP.NETMVC4应用程序,如果我使用async关键字,它会按预期工作。在大约同时创建的类库项目中,目标是4.5,我不能使用async关键字。所以我创建了一个新的ASP.NETMVC4(4.5)网络应用程序项目,但我再次无法使用asyncTypeornamespacename'async'couldnotbefound这是我觉得自己在做一些完全愚蠢的事情的问题之一。毕竟,我整个周末都在勒芒观看比赛并喝酒。我的意思是,它应该适用于任何.NET4.5项目,对吧?它是一个编译器功能。 最佳答案

Angular,NGRX/Store,以单个序列为单一的select和async调用

有人知道是否有机会从商店获得价值,然后致电AngularHTTP服务?请参见下面的示例。提前致谢。我有一个使用异步方法的服务。在此方法中,我调用AngularHTTP服务,但是在调用AngularHTTP服务之前,我想从商店(Oauth访问令牌)检索一些值。问题是我将Oauth令牌存储在商店中,我必须将令牌添加到请求中。如果服务器响应401错误,则我刷新令牌并重复请求或新令牌请求。@Injectable()exportclassInterceptor{publicget(request:Request):Observable{returnthis.store.select((s)=>s.ses

c# - 为什么 async 关键字在编译时会生成一个枚举器和附加结构?

如果我创建一个像下面这样的简单类:publicclassTestClass{publicTaskTestMethod(intsomeParameter){returnTask.FromResult(someParameter);}publicasyncTaskTestMethod(boolsomeParameter){awaitTask.FromResult(someParameter);}}并在NDepend中检查它,它表明TestMethod采取行动并成为asyncTask有一个为它生成的结构,带有一个枚举器、枚举器状态机和一些额外的东西。为什么编译器会生成一个名为TestClas

c# - 缓存来自 [n async] 工厂方法的结果,前提是它不抛出

更新:在@usr指出我错误地假设Lazy后进行了大量修改的默认线程安全模式是LazyThreadSafetyMode.PublicationOnly...我想通过async延迟计算一个值工厂方法(即它返回Task)并在成功时将其缓存。在异常(exception)情况下,我希望我可以使用它。然而,我不想成为theexceptioncachingbehavior的牺牲品。那Lazy处于默认模式(LazyThreadSafetyMode.ExecutionAndPublication)Exceptioncaching:Whenyouusefactorymethods,exceptionsar

c# - Microsoft.Bcl.Async 是如何工作的?

Microsoft.Bcl.Async使开发人员能够在没有.NETFramework4.5的情况下使用async/await关键字,他们应该以使用它们为目标。太好了,这要感谢MicrosoftCLR和语言团队的人们的辛勤工作。现在我很好奇这是如何工作的。async/await要求编译器做一些繁重的工作,将代码转换成可以执行await操作的东西。编译器最初会在.NETFramework4.0下抛出编译错误,即使它清楚地知道async/await的含义(VisualStudio2012/2013。)那么这个库如何告诉编译器不要抛出与异步操作相关的特定编译错误,并像在.NETFramewor

c# - Haskell 相当于 C# 5 async/await

我刚刚阅读了有关使用await在C#5.0中处理异步函数的新方法。和async关键字。来自C#referenceonawait的示例:privateasyncTaskSumPageSizesAsync(){//TousetheHttpClienttypeindesktopapps,youmustincludeausingdirectiveandadda//referencefortheSystem.Net.Httpnamespace.HttpClientclient=newHttpClient();//...TaskgetContentsTask=client.GetByteArray

c# - 在异步操作后立即调用 Task.Wait() 是否等同于同步运行相同的操作?

换句话说,就是vartask=SomeLongRunningOperationAsync();task.Wait();功能相同SomeLongRunningOperation();换句话说,就是vartask=SomeOtherLongRunningOperationAsync();varresult=task.Result;功能相同varresult=SomeOtherLongRunningOperation();根据Task.WaitandInlining,如果正在等待Wait的任务已经开始执行,则Wait必须阻塞。然而,如果它还没有开始执行,Wait可能能够将目标任务从它排队的调