- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
上个月我问了以下问题,这导致我学习了 TaskEx.Yield
:
Can async methods have expensive code before the first 'await'?
但是,后来我意识到这个方法实际上是将所有后续代码提交给环境 TaskScheduler
。本着真正的 DI 精神,我们的团队已同意尽可能避免使用环境实例,所以我想知道是否可以明确指定要使用的 TaskScheduler
?
像下面这样的东西会很棒:
public static YieldAwaitable Yield(TaskScheduler taskScheduler)
{
return new YieldAwaitable(taskScheduler);
}
但是,当前的 Async CTP 实现仅提供:
public static YieldAwaitable Yield()
{
return new YieldAwaitable(SynchronizationContext.Current ?? TaskScheduler.Current);
}
以下是否会提供可接受的有效替代方案?
await Task.Factory.StartNew(() => { }, CancellationToken.None, TaskCreationOptions.None, this.TaskScheduler);
最佳答案
In true DI spirit, our team has agreed to avoid using ambient instances where possible...
异步语言支持基于隐式调度上下文。我看不到这里需要依赖注入(inject)。如有必要,任何调用您的 async
方法的方法都可以提供自己的上下文。
你的选择:
await Task.Factory.StartNew(() => { }, CancellationToken.None, TaskCreationOptions.None, this.TaskScheduler);
不会按预期工作。这会将 noop lambda 排队到特定的 TaskScheduler
,然后在隐式调度上下文中恢复该方法。
Async CTP 的早期版本确实提供了一种“让步到另一个上下文”的方法,称为 SwitchTo
。它was removed因为它太容易被滥用。
就我个人而言,我认为让您的 async
代码使用其调用方法提供的隐式调度上下文会更简洁。
附言创建和安装您自己的上下文(例如,用于测试目的)并不(太)困难。我写了AsyncContext
作为单元测试和控制台程序的简单调度上下文。异步 CTP 带有用于测试的 GeneralThreadAffineContext
、WindowsFormsContext
和 WpfContext
。可以使用 SynchronizationContext.SetSynchronizationContext
安装其中任何一个。 IMO,DI 太过分了。
关于c# - TaskEx.Yield(TaskScheduler),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8742522/
我正在尝试了解何时使用 TaskEx.Run。我提供了我在下面编写的两个代码示例,它们产生了相同的结果。我看不到的是为什么我会采用 Task.RunEx TaskEx.RunEx 方法,我确信这是有充
什么是TaskEx?在 http://www.i-programmer.info/programming/c/1514-async-await-and-the-ui-problem.html?star
我在玩 HttpListener 和 Async CTP class HttpServer : IDisposable { HttpListener listener; Cancell
上个月我问了以下问题,这导致我学习了 TaskEx.Yield: Can async methods have expensive code before the first 'await'? 但是,
我在使用异步 CTP 时遇到问题,试图弄清楚处理异常的正确方法是什么。下面的代码使我的程序崩溃,据我所知,await 应该在调用它的上下文中捕获并重新抛出异常,所以 Not caught! block
我在 C# 中使用 Async Framework CTP 调用 TaskEx.Delay 时发现了一些问题 public async Task TestAsync() { return aw
我不得不使用 .NET 4.0 框架和异步 CTP 扩展来执行如下操作: var dataTasks = _tasks.Select(t => t.GetData(keys));
这只是一个想象中的问题,我希望该解决方案能够在所有类似场景中提供帮助。假设我需要计算网页上所有外部资源(图像、脚本等)的总大小。我下载页面,提取所有 SRC 信息并将 URL 列表转换为下载任务: a
我认为 TaskEx.WhenAll 会在方法中传递的所有任务完成后返回。所以在 TaskEx.WhenAll 上等待将返回 Return 语句的数组,这样当每个对象完成时,该数组将被返回。 但事实并
Task.Factory.StartNew() 基本上接收一个 Action 并返回一个 Task。在异步 CTP 中,我们有 TaskEx.Run() ,它也接收一个 Action 并返回一个任务。
我正在使用新的 TAP 模式进行探测,使用 Task 和 CTP 来实现异步方法。 我有以下代码: private async void btnAsync01_Click(object sender,
我是一名优秀的程序员,十分优秀!