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

C# 逻辑CallContext值不使用异步任务流动,c#,asynchronous,task-parallel-library,C#,Asynchronous,Task Parallel Library,根据我读到的所有内容,以下测试方法应该通过。我试图理解它为什么失败。私有异步方法中的第一个断言按预期传递。但是,一旦任务返回并等待。在CallContext中设置的值在检索时现在为null [TestMethod] public void LogicalCallContextBlockingTest() { PerformSimpleAsyncWork().Wait(); var result = CallContext.LogicalG

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

    [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");

            });   
    }

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

因此,
PerformSimpleAsyncWork
获取一个子上下文,该子上下文可以查看调用者放入上下文中的任何内容,但调用者将无法使用它所做的任何更改(
LogicalCallContextBlockingTest


如果你想了解更多信息,斯蒂芬·克利里(Stephen Cleary)对这种行为有自己的见解。

太棒了,我现在明白了。谢谢