jjzjj

c# - 具有 Task.Run 性能的 ASP.NET Web API 2 异步操作方法

我正在尝试对几个ASP.NETWebAPI2.0端点进行基准测试(使用Apache基准测试)。其中一个是同步的,一个是异步的。[Route("user/{userId}/feeds")][HttpGet]publicIEnumerableGetNewsFeedItemsForUser(stringuserId){return_newsFeedService.GetNewsFeedItemsForUser(userId);}[Route("user/{userId}/feeds/async")][HttpGet]publicasyncTask>GetNewsFeedItemsForUse

c# - AttachedToParent 任务混淆

我无法理解AttachedToParent参数的工作原理。示例代码如下:publicstaticvoidMain(string[]args){TaskparentTask=Task.Run(()=>{int[]results=newint[3];Taskt1=newTask(()=>{Thread.Sleep(3000);results[0]=0;},TaskCreationOptions.AttachedToParent);Taskt2=newTask(()=>{Thread.Sleep(3000);results[1]=1;},TaskCreationOptions.Attache

c# - 在 TPL 中返回一个空的静态任务是一种不好的做法吗?

有些情况下我想有条件地运行任务。我使用这样的某种扩展方法:publicstaticclassMyTaskExtension{privatestaticTasktheEmptyTask=Task.Factory.StartNew(()=>{});//ThisisthequestionpublicstaticTaskContinueWith(thisTasktask,TaskcontinuationTask,Funccondition){ifcondition(){...dothework}returntheEmptyTask;}}我的期望是theEmptyTask已经完成,所以基本上如果

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

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

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# - 支持 .NET 4.0 中的进度报告和增量结果 "Task Parallel Library"

我知道TaskParallelLibrary仍处于测试阶段,可用资源可能会减少,但从我所读的内容来看,图书馆对taskscheduling给予了非常特殊的对待。,exceptionhandling和cancellation.但我没有找到任何关于进度报告和发送增量结果的任务引用。这两件事似乎太重要了,不容忽视。您能否阐明如何在任务并行库中处理这些问题或引用一些解释它们的文章? 最佳答案 这个例子更新了一个进度条:usingSystem;usingSystem.Threading;usingSystem.Threading.Tasks;

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

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

c# - 无法将类型 'Task<Derived>' 转换为 'Task<Interface>'

我有以下带有委托(delegate)参数的函数,它接受一个接口(interface)的类型并返回另一个接口(interface)的任务。publicvoidBar(Func>func){thrownewNotImplementedException();}我还有一个带有参数的函数作为IMessage的实例并返回一个任务。Message和Result是IMessage的实现和IResult分别。privateTaskDoSomething(Messagem){returnnewTask(()=>newResult());}当我将DoSomething传递到Bar时收到错误。Bar(m=>

c# - 构建 Office 加载项时程序集绑定(bind)错误 : "FindRibbons" task failed unexpectedly

我们正在尝试设置Jenkins(构建服务器)作业以基于VSTO构建我们的Office加载项。但是,在将DLL复制到项目的bin目录后,我不断收到构建过程失败的奇怪错误:Error11The"FindRibbons"taskfailedunexpectedly.System.IO.FileNotFoundException:Couldnotloadfileorassembly'MyAddIn,Version=1.0.0.0,Culture=neutral,PublicKeyToken=null'oroneofitsdependencies.Thesystemcannotfindthefi

c# - 如何创建任务<>我可以手动完成

在对组件进行单元测试时,我需要验证组件如何对在不同时间完成的任务使用react。如何创建Task我可以随意解决? 最佳答案 您可以使用TaskCompletionSource创建一个完全“手动”的任务。RepresentstheproducersideofaTaskunboundtoadelegate,providingaccesstotheconsumersidethroughtheTaskproperty.将完成源的Task属性交给消费者,并(随意)调用SetResult来完成任务。请注意,您还有SetCanceled和SetE