草庐IT

任务数

全部标签

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

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

c# - 如果我等待一个已经在运行或运行的任务,会发生什么?

有一个Task变量,可以说任务现在正在运行......通过执行以下行。await_task;我想知道当我写这段代码时会发生什么:await_task;await_task;它会执行两次任务吗?或者因为它已经运行而抛出异常? 最佳答案 woulditexecutethetasktwice?Orthrowanexceptionbecauseithasalreadyrun?没有也没有。唯一await就是调用Task.GetAwaiter,它不会导致任何东西运行。如果任务已经运行完成,如果它是Task,它将提取值。,或者如果是Task则同步

c# - 从 ASP.NET Core 中的 Controller 操作运行后台任务

我正在使用C#和ASP.NETCore2.0开发带有RESTAPI的Web应用程序。我想要实现的是,当客户端向端点发送请求时,我将运行一个与客户端请求上下文分离的后台任务,如果任务成功启动,该任务将结束。我知道有HostedService但问题是HostedService在服务器启动时启动,据我所知没有办法启动HostedService从Controller手动。这是演示问题的简单代码。[Authorize(AuthenticationSchemes="UsersScheme")]publicclassUsersController:Controller{[HttpPost]publi

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# - 如何创建任务<>我可以手动完成

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

c# - 如何在 ASP.NET Web API 中对后台任务进行排队

我有一个webapi,旨在以队列方式处理报告。应用程序执行的步骤如下:接收内容将内容映射到一个对象并将其放入队列轮询队列中的未决项目一次处理一个队列中的项目我在考虑使用EntityFramework来创建一个队列项目的数据库,例如:publicclassEFBatchItem{[Key]publicstringBatchId{get;set;}publicDateTimeDateCreated{get;set;}publicDateTimeDateCompleted{get;set;}publicstringBatchItem{get;set;}publicBatchStatusSta

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

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

c# - 分钟内的 Hangfire 重复任务

有没有办法每隔几秒设置hangfire重复作业?我不寻求一种即发即弃任务会产生另一个即发即忘任务的解决方案,如果不是,建议的替代方案是什么? 最佳答案 不确定何时支持此功能,但在ASP.NETCore2.0和Hangfire1.7.0中尝试过此功能。以下代码每20秒安排一次作业:RecurringJob.AddOrUpdate(x=>x.DoWork(),"*/20*****");如果我没记错的话,由于Hangfire使用了NCrontab,所以支持6个token(而不是标准的5个token)它允许具有6个标记的cron表达式(第二

c# - 任务链(等待上一个任务完成)

vartasks=newList();foreach(varguidinguids){vartask=newTask(...);tasks.Add(task);}foreach(vartaskintasks){task.Start();Task.WaitAll(task);}这是UI线程的运行。我需要一个接一个地执行任务变量中的所有任务。问题是如果我调用Task.WaitAll(task),UI会卡住。如何在不卡住UI的情况下执行以下逻辑? 最佳答案 这不是任务链。您需要使用ContinueWith进行任务链接。最后一个任务需要更新

c# - CancellationToken.ThrowIfCancellationRequested 后的故障与取消任务状态

通常我不会发布带有答案的问题,但这次我想引起一些人对我认为可能是一个晦涩但普遍的问题的关注。它是由thisquestion触发的,从那以后我检查了我自己的旧代码,发现其中一些也受此影响。下面的代码启动并等待两个任务,task1和task2,它们几乎相同。task1与task2的唯一区别在于它运行一个永无止境的循环。IMO,这两种情况对于一些执行CPU密集型工作的现实场景来说都是非常典型的。usingSystem;usingSystem.Threading;usingSystem.Threading.Tasks;namespaceConsoleApplication{publicclas