task-parallel-library
全部标签 我在可移植类库类中遇到问题。尽管引用了System.Linq,但我似乎无法使用.AsParallel()扩展方法。这是代码:usingSystem;usingSystem.Collections.Generic;usingSystem.Linq;usingSystem.Text;usingSystem.Threading.Tasks;namespacePortableClassLibrary1{publicclassClass1{publicClass1(){varlist=newList();}}}list没有AsParallel()方法,它只有AsQueryable和AsEnume
我在不同的任务上运行了一个非常典型的生产者/消费者模型。任务1:从二进制文件中读取成批的byte[]并为每个字节数组集合启动一个新任务。(出于内存管理目的,该操作是批处理的)。任务2-n:这些是工作任务,每个任务都对传入的字节数组集合(来自Tasks1)进行操作并反序列化字节数组,按特定标准对它们进行排序,然后存储结果对象的集合(每个字节数组在并发字典中反序列化为此类对象。任务(n+1)我选择了一个并发字典,因为这个任务的工作是合并存储在并发字典中的那些集合,其顺序与它们来自Task1的顺序相同。我通过从Task1一直向下传递到此任务的collectionID(它的类型为int并为Ta
关闭。这个问题不符合StackOverflowguidelines.它目前不接受答案。要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于StackOverflow来说是偏离主题的,因为它们往往会吸引自以为是的答案和垃圾邮件。相反,describetheproblem以及迄今为止为解决该问题所做的工作。关闭8年前。Improvethisquestion我正在用c#实现并发.NET数据结构(如ConcurrentDictionary、BlockcingCollection等)。这不仅仅是在从不同线程访问时不要忘记锁定对象。它需要复杂的锁定策略来最大化并行执行时间。我知道有一个工具,一种
我遇到了一个单元测试失败的问题,因为TPL任务从未执行过它的ContinueWith(x,TaskScheduler.FromCurrentSynchronizationContext())。问题原来是因为在任务启动之前不小心创建了一个WinformsUI控件。这是一个重现它的例子。您会看到,如果您按原样运行测试,它就会通过。如果您在未注释Form行的情况下运行测试,它将失败。[TestClass]publicclassUnitTest1{[TestMethod]publicvoidTestMethod1(){//CreatenewsynccontextforunittestSynch
几乎每个SO关于此主题的回答都指出:LINQdoesn'tworkperfectlywithasync还有:Irecommendthatyounotthinkofthisas"usingasyncwithinLINQ"但在Stephen的书中有一个示例:Problem:Youhaveacollectionoftaskstoawait,andyouwanttodosomeprocessingoneachtaskafteritcompletes.However,youwanttodotheprocessingforeachoneassoonasitcompletes,notwaitingf
根据MSDN:Createsataskthatwillcompletewhenallofthesuppliedtaskshavecompleted.当调用Task.WhenAll()时,它会创建一个任务,但这是否一定意味着它会创建一个新线程来执行该任务?例如,下面这个控制台应用程序中创建了多少个线程?classProgram{staticvoidMain(string[]args){RunAsync();Console.ReadKey();}publicstaticasyncTaskRunAsync(){Stopwatchsw=newStopwatch();sw.Start();Tas
所以我一直在深入研究HttpClient.SendAsync的实现通过反射器。我有意想知道这些方法的执行流程,并确定调用哪个API来执行异步IO工作。探索里面的各个类之后HttpClient,我看到它在内部使用HttpClientHandler源自HttpMessageHandler并实现其SendAsync方法。这是HttpClientHandler.SendAsync的实现:protectedinternaloverrideTaskSendAsync(HttpRequestMessagerequest,CancellationTokencancellationToken){if(r
我是C#5.0中的async-await方法的新手,我脑子里的问题很少如果async方法未通过输入参数或null检查,最好的转义方法是什么?在Taskasync方法中使用return;的逻辑流程是什么(在某些情况下,它变成了无限循环)?CancellationToken或Task.Yield是否更适合这种情况?publicFuncUploadSuccessCallBackAsync{get;set;}privateasyncTaskOnUploadSuccessAsync(AzureBlobInfoinfo){if(this.UploadSuccessCallBackAsync==nu
我正在努力了解async/await并认为我确实了解有关用法的一些事情。但仍然不太清楚在下面的场景中实际好处是什么。查看Task.Run用法。第一种方法使用普通委托(delegate)并使用Thread.Sleep,但第二种方法使用“异步”委托(delegate)和Task.Delay。我的问题是:这对这个方法有什么影响(或没有影响)?该方法本身是一个异步方法。该代码正在创建一个单独的线程(通过Task.Run),并且该线程除了执行该委托(delegate)之外别无他法。因此,即使它在Task.Delay上产生等待,在这种情况下有什么用,因为线程无论如何都是一个孤立的线程,不用于任何其
遇到问题,希望有人能帮我解决。我尝试在循环中启动4个任务,但我收到ArgumentOutOfRangeException:for(inti=0;i.Run(()=>GetData(i,plcPool[i]));}循环因为i=4而溢出如果我在没有循环的情况下启动任务,它们会毫无问题地运行:tasks[0]=Task.Run(()=>GetData(0,plcPool[0]));tasks[1]=Task.Run(()=>GetData(1,plcPool[1]));tasks[2]=Task.Run(()=>GetData(2,plcPool[2]));tasks[3]=Task.Run