使用异步任务不流动的逻辑CallContext值

时间:2014-10-03 17:54:35

标签: c# asynchronous task-parallel-library

根据我读过的所有内容,应该通过以下测试方法。我试图理解它失败的原因。私有异步方法中的第一个断言按预期传递。但是,一旦任务返回并等待。检索时,CallContext中设置的值现在为空。

    [TestMethod]
    public void LogicalCallContextBlockingTest()
    {
        PerformSimpleAsyncWork().Wait();

        var result = CallContext.LogicalGetData("test");

        Assert.AreEqual(result, "expected");
    }       

    private async Task PerformSimpleAsyncWork()
    {
        await Task.Run(() =>
            {
                System.Threading.Thread.Sleep(100);
                CallContext.LogicalSetData("test", "expected");

                var result = CallContext.LogicalGetData("test");

                Assert.AreEqual(result, "expected");

            });   
    }

1 个答案:

答案 0 :(得分:10)

使用async关键字修饰的方法在调用时创建子上下文。对此子上下文所做的任何更改都不会传播到父上下文。

因此,PerformSimpleAsyncWork获取一个子上下文,该上下文可以看到调用者放入上下文的任何内容,但是它所做的任何更改都不可用于调用者(LogicalCallContextBlockingTest)。 / p> 如果您想了解更多信息,Stephen Cleary对此行为有good writeup