草庐IT

task_completion_source

全部标签

c# - 使用 : HandleRef or IntPtr (newer source code from Microsoft no longer uses HandleRef) 哪个更好/更安全

例如,在旧的.NETFramework2.0源代码(Windows窗体、VisualStudio2005-Whidbey)中,GetClientRect函数是使用HandleRef定义的:[DllImport(ExternDll.User32,ExactSpelling=true,CharSet=CharSet.Auto)]publicstaticexternboolGetClientRect(HandleRefhWnd,[In,Out]refNativeMethods.RECTrect);在新的WindowsAPI代码包(来自Microsoft,2009/2010)中,使用IntPt

c# - 我应该怎么做才能在 .NET 2.0 中使用 Task<T>?

.NET4.0有TPL,它包含很好的Task类来封装异步编程模型。我正在开发一个必须是.NET2.0的应用程序,但我想避免重写Task。有什么建议吗? 最佳答案 我知道你说过你不想重写Task,但实际上你可以使用闭包创建一些相当简单的东西,它的行为有点像Task对象。这是我使用的:publicdelegateRAsyncTask();publicstaticAsyncTaskBeginTask(AsyncTaskfunction){Rretv=default(R);boolcompleted=false;objectsync=new

c# - 是否应该重写所有接口(interface)以返回 Task<Result>?

我有一个简单的界面publicinterfaceSomethingProvider{publicSomethingGetSomething();}为了“使”它异步,我会这样做publicinterfaceSomethingProvider{publicTaskGetSomethingAsync();}虽然接口(interface)现在暗示GetSomething是异步的,但它允许同步执行,如果同步结果足够快,这很好。如果它阻塞,那么我可以将责任归咎于实现程序员对接口(interface)的不良实现。因此,如果后一个接口(interface)由足够快的阻塞实现来实现,则后一个接口(int

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# - 支持 .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# - 如何结合 TaskCompletionSource 和 CancellationTokenSource?

我有这样的代码(此处已简化)等待完成任务:vartask_completion_source=newTaskCompletionSource();observable.Subscribe(b=>{if(b)task_completion_source.SetResult(true);});awaittask_completion_source.Task;想法是订阅并等待bool值流中的true。这完成了“任务”,我可以继续超越await。但是我想取消--但不是订阅,而是等待。我想将取消token(以某种方式)传递给task_completion_source,因此当我取消token源时

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# - 带有异步 lambda 和 Task.WaitAll 的 Task.Factory.StartNew

我正在尝试对任务列表使用Task.WaitAll。问题是任务是一个异步lambda,它会破坏Tasks.WaitAll,因为它从不等待。这是一个示例代码块:Listtasks=newList();tasks.Add(Task.Factory.StartNew(async()=>{using(dbContext=newDatabaseContext()){varrecords=awaitdbContext.Where(r=>r.Id=100).ToListAsync();//dolongcpuprocesshere...}}Task.WaitAll(tasks);//domorestuf