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