jjzjj

c# - 清理 TPL 中的 CallContext

根据我使用的是基于async/await的代码还是基于TPL的代码,我得到了关于清理逻辑CallContext的两种不同行为。如果我使用以下异步/等待代码,我可以完全按照预期设置和清除逻辑CallContext:classProgram{staticasyncTaskDoSomething(){CallContext.LogicalSetData("hello","world");awaitTask.Run(()=>Debug.WriteLine(new{Place="Task.Run",Id=Thread.CurrentThread.ManagedThreadId,Msg=CallC

c# - 等待新任务 <T>( ... ) : Task does not run?

问题的延续here:在上述问题中,我有以下函数返回一个任务类型的对象(用于增量测试目的):privatestaticTaskGetInstance(){returnnewTask((Func>)(async()=>{awaitSimpleMessage.ShowAsync("TEST");returnnewobject();}));}当我调用awaitGetInstance();时,该函数被调用(并且我假设任务已返回,因为没有抛出异常)但任务就在那里。我只能猜测我做错了。我不希望此函数返回一个已经在运行的任务(即IMPERATIVE).如何异步运行此函数返回的任务?

c# - 任务完成

我有一个创建多个任务的循环,如下所示。我如何在每个任务完成时更新屏幕(向包含一些数据的文本框添加新行)?如何检测所有任务何时完成?C#代码for(inti=0;iTaskRequest(int.Parse(radTextBoxFirstNumber.Text),int.Parse(radTextBoxSecondNumber.Text),int.Parse(radTextBoxFloodDelay.Text),x));//Startthetask.taskA.Start();}privatevoidTaskRequest(intnumber1,intnumber2,intdelay,i

c# - 对 CancellationTokenSource.Cancel 的调用永远不会返回

我有一种情况,对CancellationTokenSource.Cancel的调用永远不会返回。相反,在Cancel被调用之后(在它返回之前),执行将继续执行被取消代码的取消代码。如果被取消的代码随后没有调用任何可等待的代码,那么最初调用Cancel的调用者永远不会取回控制权。这很奇怪。我希望Cancel简单地记录取消请求并立即返回独立于取消本身。事实上,调用Cancel的线程最终会执行属于被取消操作的代码,并且在返回给Cancel的调用者之前这样做看起来像框架中的错误。这是怎么回事:有一段代码,我们称之为“工作代码”,它正在等待一些异步代码。为简单起见,假设此代码正在等待Task.D

c# - 没有 "threads"的异步和等待?我可以自定义引擎盖下发生的事情吗?

我有一个关于如何自定义新async的问题/await关键字和TaskC#4.5中的类是。首先了解我的问题的一些背景知识:我正在开发具有以下设计的框架:一个线程有一个“当前待办事项”列表(通常大约有100到200个项目),这些列表存储为自己的数据结构并作为列表保存。它有一个Update()枚举列表并查看某些“事物”是否需要执行并执行的函数。基本上它就像一个大线程调度器。为了简化事情,让我们假设“要做的事情”是返回bool值true的函数。当它们“完成”时(不应称为下一次更新)和false下次更新时调度程序应该再次调用它们。所有“事物”不能并发运行,也必须在一个线程中运行(因为线程静态变量

c# - 如何在 .net 3.5 中获得 Task<T> 的等价物?

我有一些代码正在使用Task它会在短时间内延迟从串行读取操作返回结果,如下所示:voidReturnResponseAfterAShortDelay(){if(delayedResponseCancellationTokenSource!=null)delayedResponseCancellationTokenSource.Cancel();//Cancelanypendingoperationsandstartanewone.delayedResponseCancellationTokenSource=newCancellationTokenSource();log.InfoFor

c# - 如何在 C# 中运行多个任务并在完成这些任务时获取事件?

我正在重新运行Task完成后。下面是我在应用程序的Application_Start中调用的函数。privatevoidRun(){Taskt=newTask(()=>newXyzServices().ProcessXyz());t.Start();t.ContinueWith((x)=>{Thread.Sleep(ConfigReader.CronReRunTimeInSeconds);Run();});}我想运行多个任务,这些任务将从web.config应用程序设置中读取。我正在尝试这样的事情,privatevoidRun(){Listtasks=newList();for(int

c# - 链接两个函数 () -> Task<A> 和 A->Task<B>

不知道是不是我对TPL的理解有误,但是我很难理解如何获得以下内容:我有两个功能TaskgetA(){...}TaskgetB(Aa){...}这似乎经常发生:我可以异步地得到一个A。给定一个A,我可以异步地得到一个B。我想不出在TPL中将这些函数链接在一起的正确方法。这是一个尝试:TaskCombined(){Taskta=getA();Task>ttb=ta.ContinueWith(a=>getB(a.Result));returnttb.ContinueWith(x=>x.Result.Result);}ContinueWith是我感到困惑的地方。返回的类型是“双重任务”,Tas

c# - 了解一行中使用的 Task.Run + Wait() + async + await 的使用

我是C#新手,所以我在理解一些概念时遇到了困难,并且遇到了一段我不太理解的代码:staticvoidMain(string[]args){Task.Run(async()=>{awaitSomeClass.Initiate(newConfiguration());}).Wait();while(true);}据我了解,这会运行一个启动方法的任务。此方法运行,然后,一旦完成,就会进入无限循环等待。感觉要么是代码没看懂,要么是我没理解对。谢谢 最佳答案 你可以把它分成几个部分:async()=>{awaitSomeClass.Initi

没有等待或返回的 C# 异步任务方法

我有一个在两个地方实现的接口(interface)I,例如:interfaceI{TaskDoSomething();}该接口(interface)具有异步任务DoSomething方法API,然后在类A中实现,例如:classA:I{....}classB:I{....}在类A中,DoSomething的实现如下,没问题:publicasyncTaskDoSomething(){if(...){awaitDoIt();}}但是,在类B中,DoSomething()的实现不应执行任何操作。所以,它的实现看起来像这样:publicasyncTaskDoSomething(){//noth