TaskScheduler を使用してみるために、次のコードを記述します。関数内のタスク コンテンツはUpdateStatus
、メイン スレッドで実行する必要があります。しかし、出力が別のスレッドで実行されていることを示しているだけです。
理由についてのアイデアはありますか?または、メイン スレッド コンテキストでバックグラウンド スレッドからステータスを書き込む代替方法。
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
namespace ConsoleApplication1
{
class Test
{
TaskScheduler scheduler;
public void Run()
{
SynchronizationContext.SetSynchronizationContext(new SynchronizationContext());
scheduler = TaskScheduler.FromCurrentSynchronizationContext();
Console.WriteLine("Start on {0}", Thread.CurrentThread.ManagedThreadId);
Task.Factory.StartNew(() =>
{
for (int i = 0; i < 10; i++)
{
Console.WriteLine("running on {0}", Thread.CurrentThread.ManagedThreadId);
UpdateStatus(string.Format("Message {0}", i));
Thread.Sleep(1000);
}
}).ContinueWith(_ =>
{
Console.WriteLine("complate");
Console.WriteLine("running on {0}", Thread.CurrentThread.ManagedThreadId);
}, new CancellationToken(), TaskContinuationOptions.None, scheduler).Wait();
}
private void UpdateStatus(string message)
{
Task.Factory.StartNew(() =>
{
Console.WriteLine("updating status on {0}", Thread.CurrentThread.ManagedThreadId);
Console.WriteLine(message);
}, new CancellationToken(), TaskCreationOptions.None, scheduler);
}
}
class Program
{
public static void Main(string[] args)
{
var test = new Test();
test.Run();
}
}
}