草庐IT

多任务

全部标签

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

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

c# - 带有 await 的异步 lambda 表达式返回任务?

我有以下代码://Getallofthefilesfromthelocalstoragedirectory.varfiles=awaitfolder.GetFilesAsync();//Mapeachfiletoastreamcorrespondingtothatfile.varstreams=files.Select(asyncf=>{returnawaitf.OpenStreamForWriteAsync();});我希望streams类型为IEnumerable但实际上是IEnumberable>,如果我省略了await关键字,这就是我所期望的。OpenStreamForWrit

c# - 单击按钮期间是否可以等待异步任务?

我的应用程序中有一个刷新按钮,它使用一些异步方法来更新显示的项目列表。问题是我不能为按钮单击的事件处理程序返回Task类型,所以我只剩下一个asyncvoid方法。因此,用户可以点击刷新按钮,然后在重新填充列表时选择一个项目,这将导致错误。处理按钮点击的代码开始:privateasyncvoidButton_Click_1(objectsender,RoutedEventArgse){awaitViewModel.CreateMessageCommand();那么有什么方法可以正确地等待这个任务完成吗? 最佳答案 由于控件的事件处理

c# - 如何同步任务?

假设我有一个保存到文件的异步方法:asyncTaskSaveToFileAsync(){varfile=awaitfolder.GetFileAsync(...)varstream=file.OpenFileAsync(...)///etc}现在假设同时调用了两次SaveToFileAsync。这是一个问题,因为您不能同时写入同一个文件如果这是一个常规方法,lock()会解决这个问题:voidSaveToFile(){lock(something){///codehere}}但是,在异步方法中不允许使用锁。当然,可以调用Monitor.Enter()或使用互斥体,但这些对象与线程一起工

c# - 有没有一种简单的方法可以返回异常的任务?

我的理解是returnTask.FromResult(foo)是以下内容的简单简写:vartcs=newTaskCompletionSource();tcs.SetResult(foo);returntcs.Task;返回异常状态的任务是否有一些等价物?vartcs=newTaskCompletionSource();tcs.SetException(newNotSupportedException());//orwhateverisappropriatereturntcs.Task;我没有看到类似Task.FromException的内容。还是只抛出异常而不返回任务更合适?

C# - 更改任务栏的图标

我想更改我软件任务栏上的图标,所以我更改了项目设置。此路径由VisualStudio本身建议但我的任务栏仍然显示与以前相同的图标(标准图标)-在我的资源管理器中,.exe具有正确的图标,只是不会在任务栏中更改。我还尝试结束explorer.exe并重新启动任务,但这根本没有帮助。我还尝试将分辨率设置为16x16和32x32,但均无效。 最佳答案 您还需要为表单提供该图标。应用程序图标是嵌入在应用程序中并显示在资源管理器或快捷方式上的图标。不过,每个表单都可以有自己的图标。 关于C#-更改

c# - 在 TPL 中中止长时间运行的任务

我们的应用程序使用TPL来序列化(可能)长时间运行的工作单元。工作(任务)的创建是用户驱动的,可以随时取消。为了拥有一个响应式的用户界面,如果不再需要当前的工作,我们想放弃我们正在做的事情,并立即开始一个不同的任务。任务排队是这样的:privateTaskworkQueue;privatevoidDoWorkAsync(Actioncallback,CancellationTokentoken){if(workQueue==null){workQueue=Task.Factory.StartWork(()=>DoWork(callback,token),token);}else{wor

c# - 带有 yield 返回的异步任务<IEnumerable>?

以下方法无法编译。替代方案?publicstaticasyncTask>GetRecordsAsync(thisTransactiontransaction,stringcommandText,paramsSqlParameter[]parameters){//GetaSqlDataReadervarreader=awaittransaction.GetReaderAsync(commandText,parameters);varfieldCount=-1;//Beginiteratingthroughrecordsasynchronouslywhile(awaitreader.Rea

c# - 如何将异步操作与 .NET 4 中的任务并行库链接起来?

我正在尝试以编程方式在C#4中链接异步操作,例如写入给定的Stream对象。我最初是“手动”执行此操作的,将回调从一个操作Hook到下一个操作,但我想我会尝试使用.NET4任务并行库来省去重新发明并发轮子的麻烦。首先,我将异步调用包装在任务中,如下所示:publicstaticTaskCreateWriteTask(Streamstream,byte[]data){returnTask.Factory.FromAsync(stream.BeginWrite,stream.EndWrite,data,0,data.Length,null);}Continuations使链式同步操作变得非

c# - 如何命名运行任务的线程?

我发现命名线程在调试时非常有用。我看不出有什么方法可以使用Task.Factory.StartNew()的参数来命名线程那么在任务中显式命名线程是否可以接受?例如:privatevoidMyFunc(){Task.Factory.StartNew(()=>{Thread.CurrentThread.Name="Foobulizer";Foobulize();});}但是,我很欣赏线程可能会被不同的任务重用,所以我是否需要在任务结束时显式地重置线程名称?这感觉很老套,所以我认为这可能是个坏主意,或者有正确的方法来做到这一点? 最佳答案