マイクロソフトからの次の情報のため、私は少しコードを更新しました。現在のカルチャーを私が使うことのできるものにアップデートしたようです。 CultureInfo.CurrentCultureとCultureInfo.CurrentUICulture非同期横切っ 操作を流れるスレッドののExecutionContextに に格納されている の.NET Framework 4.6およびそれ以降のバージョンが、ターゲットアプリケーションについて.net-4.6の非同期Thread.CurrentThread.CurrentCulture
。 (ソース:https://msdn.microsoft.com/en-us/library/dn833123(v=vs.110).aspx)
using System;
using System.Globalization;
using System.Threading;
using System.Threading.Tasks;
class Program
{
static void Main(string[] args)
{
Console.WriteLine("start " + Thread.CurrentThread.CurrentCulture.ToString() + " " + Thread.CurrentThread.ManagedThreadId);
RunAsync().Wait();
Console.WriteLine("Finish " + Thread.CurrentThread.CurrentCulture.ToString() + " " + Thread.CurrentThread.ManagedThreadId);
Console.ReadKey();
}
static async Task RunAsync()
{
Thread.CurrentThread.CurrentCulture = new System.Globalization.CultureInfo("de-DE");
Console.WriteLine("1 " + Thread.CurrentThread.CurrentCulture.ToString() + " " + Thread.CurrentThread.ManagedThreadId);
string cultureInTask = string.Empty;
await Task.Run(() => cultureInTask = Thread.CurrentThread.CurrentCulture.ToString() + " " + Thread.CurrentThread.ManagedThreadId).ConfigureAwait(true);
Console.WriteLine("2 " + cultureInTask);
string twoA = await TestMethodAsync();
Console.WriteLine("2a " + twoA + " " + Thread.CurrentThread.ManagedThreadId);
Console.WriteLine("3 " + Thread.CurrentThread.CurrentCulture.ToString() + " " + Thread.CurrentThread.ManagedThreadId);
}
public static async Task<string> TestMethodAsync()
{
Console.WriteLine("2s " + Thread.CurrentThread.CurrentCulture.ToString() + " " + Thread.CurrentThread.ManagedThreadId);
return await Task.Run(() =>
{
return System.Threading.Thread.CurrentThread.CurrentUICulture.ToString() + " " + Thread.CurrentThread.ManagedThreadId;
});
}
}
出力:
start en-US 1
1 de-DE 1
2 de-DE 3
2s de-DE 3
2a en-US 4 4
3 de-DE 4
Finish en-US 1
しかし、なぜ2aはEN-USはなく、デDE戻っていますか?それはexecutionContextが異なるためですか?もしそうなら、どうすれば同じ実行コンテキストに留まることができますか?
引用したドキュメントにリンクすることはできますか? –
https://msdn.microsoft.com/en-us/library/dn833123(v=vs.110).aspxまた、メインポストで編集しました – user1408786
一度作業してしまえばこれを誤植として閉じようとしましたそれは、しかし、私はそれに答えるには十分に面白いと思う... –