草庐IT

Async-await

全部标签

c# - 使用 Async 避免重复代码

如何避免为异步和非异步方法编写两次相同的代码。我目前正在使用ASP.NET,所以我目前在请求线程上,我很快了解到他在代码下方(应该显示我的意图)绝对是错误的做法。应用程序死锁,因为await关键字试图返回到.Result阻塞的同一个线程。我这样做的全部原因是为了避免两次编写相同的“FindAll”代码。publicIEnumerableFindAll(){returnFindAllAsync().Result;}publicasyncTask>FindAllAsync(){returnawaitContext.Resources.ToListAsync();}那么如何解决这个问题呢?

c# - 我可以等待我用生成器创建的可枚举吗?

假设我有一个异步获取的整数序列。asyncTaskGetI(inti){returnawaitTask.Delay(1000).ContinueWith(x=>i);}我想在该序列上创建一个生成器,如果该序列是同步的,我会这样做:IEnumerableMethod(){for(vari=0;i所以,我想这个类比是让生成器异步并从中产生:asyncTask>Method(){for(vari=0;ii);}}这行不通,因为一个带有yield的方法必须返回IEnumerable更有意义的替代方案是IEnumerable>但自async以来将无法编译方法必须返回Tasks或无效。现在,我意识

c# - 为什么 GC 在我引用它时收集我的对象?

让我们看看下面显示问题的片段。classProgram{staticvoidMain(string[]args){vartask=Start();Task.Run(()=>{Thread.Sleep(500);Console.WriteLine("StartingGC");GC.Collect();GC.WaitForPendingFinalizers();Console.WriteLine("GCDone");});task.Wait();Console.Read();}privatestaticasyncTaskStart(){Console.WriteLine("Start");

c# - UOW - 在上一个异步操作完成之前,第二个操作在此上下文中开始

我正在尝试下面的代码,它有两个部分,一个是通过棱镜导航。当允许导航时,我会异步启动深度加载,但每次都有一个新的上下文。在后面的代码中,我想取消未完成此加载的挂起导航,但下面的代码甚至不起作用,所以取消是以后的事;-)导航逻辑:这里没有问题publicvoidOnNavigatedTo(NavigationContextnavigationContext){intrelatieId=(int)navigationContext.Parameters["RelatieId"];if(_relatie!=null&&_relatie.RelatieId==relatieId)return;l

c# - 纤程与异步等待

我正在加入一个C#项目,开发人员在其中大量使用Fibers.在这个项目之前我什至没有听说过它们并且以前使用过asyncawait和Threads和BackgroundWorker来进行我的多任务操作。今天我问他们为什么使用Fiber,主要开发人员说这样更容易调试。这意味着他知道特定函数来自哪个线程,甚至可以访问堆栈中更高层的变量。我想知道使用Fiber与使用新的asyncawait和使用Thread的优缺点是什么。PS:我们使用的是.Net4.5 最佳答案 IwasaskingthemwhytheyusedFibersandthem

c# - SemaphoreSlim (.NET) 是否阻止同一线程进入 block ?

我已经阅读了SemaphoreSlim的文档SemaphoreSlimMSDN这表明如果您将SemaphoreSlim配置为:SemaphoreSlim_semaphoreSlim=newSemaphoreSlim(1,1);但是,它并不表示它是否会阻止相同线程访问该代码。这与async和await一起出现。如果在方法中使用await,则控制离开该方法并在任何任务或线程完成时返回。在我的示例中,我使用带有异步按钮处理程序的按钮。它使用“await”调用另一个方法(Function1)。Function1依次调用awaitTask.Run(()=>Function2(beginCount

c# - 响应式扩展订阅调用等待

我想针对响应式扩展Observable引发的每个事件执行异步调用。我还试图使所有内容保持同步,因为我希望在处理下一个事件之前完成异步调用。如何做类似于以下的事情?我说类似是因为下面的代码无法编译。settingsChangedInMemory.Subscribe(async_=>{varsettings=Extract();awaitSaveSettings(settings);});我不确定它是否改变了什么,但我需要订阅多个Observable。例如另一个像这样的订阅。settingsChangedOnDisk.Subscribe(async_=>{varsettings=await

c# - 为什么我必须使用等待异步运行的方法。如果我不想在继续之前等待方法完成怎么办?

这个问题在这里已经有了答案:Fire-and-forgetwithasyncvs"oldasyncdelegate"(5个答案)关闭7年前。我整天都在翻阅MSDN文档,他们的异步编码理念让我感到困惑。据我了解,如果调用异步方法,调用异步方法的线程不会被阻塞。然而,async在示例中总是与await配对,这似乎否定了异步性,使得外部方法无论如何都必须等待代码执行。我不应该能够调用异步方法然后继续执行外部方法吗?我或多或少遇到过这种情况:voidreportSomethingHappened(info)-Collectinfo-HTTPPOSTinfotologgingserver(ie.

c# - 强制调用一次异步方法

假设我有一个类需要使用InitializeAsync()方法执行一些异步初始化。我想确保只执行一次初始化。如果另一个线程在初始化过程中调用此方法,它将“等待”直到第一个调用返回。我正在考虑以下实现(使用SemaphoreSlim)。有更好/更简单的方法吗?publicclassMyService:IMyService{privatereadonlySemaphoreSlimmSemaphore=newSemaphoreSlim(1,1);privateboolmIsInitialized;publicasyncTaskInitializeAsync(){if(!mIsInitializ

c# - MVC Controller 的操作中的异步/等待

我在ASP.netMVCController中有一个Index操作。此操作调用(除其他事项外)对具有大量行的SQL表进行计数的私有(private)操作。返回的数字将插入到View包属性中。publicActionResultIndex(){//dothingsViewBag.NumberOfRows=NumberOfRows();returnView();}privatestringNumberOfRows(){//sqlconnectionandrowcountreturnnumberOfRows;}这行得通,但在执行所有内容之前我看不到索引页面,甚至是行数。相反,我会立即完成In