17

http://msdn.microsoft.com/en-us/library/dd988458.aspx

更新日:

それでは、この記事について説明しましょう: http://msdn.microsoft.com/en-us/library/dd997396.aspx

私はそのコードを少し変更しました:

    static void Main()
    {

        var tokenSource2 = new CancellationTokenSource();
        CancellationToken ct = tokenSource2.Token;

        var task = Task.Factory.StartNew(() =>
        {

            // Were we already canceled?
            ct.ThrowIfCancellationRequested();

            bool moreToDo = true;
            Thread.Sleep(5000);
            while (moreToDo)
            {

                // Poll on this property if you have to do
                // other cleanup before throwing.
                if (ct.IsCancellationRequested)
                {
                    Console.WriteLine("exit");
                    // Clean up here, then...
                    ct.ThrowIfCancellationRequested();
                }

            }
        }, tokenSource2.Token); // this parameter useless

        Console.WriteLine("sleep");
        Thread.Sleep(2000);
        Console.WriteLine("cancel");

        tokenSource2.Cancel();

        // Just continue on this thread, or Wait/WaitAll with try-catch:
        try
        {
            task.Wait();
        }
        catch (AggregateException e)
        {
            foreach (var v in e.InnerExceptions)
            {
                Console.WriteLine(e.Message + " " + v.Message);
            }
        }

        Console.ReadKey();
    }

UPD :まあ、これは変更のみtask.IsCanceledです。これは、私はまだすべてを手動で実装する必要があるため、役に立ちません。

4

2 に答える 2

43

コメントのため、別の回答を投稿しています。

次のコードを検討してください。

var tokenSource = new CancellationTokenSource();
CancellationToken ct = tokenSource.Token;

tokenSource.Cancel(); 

var task = Task.Factory.StartNew(() =>
{    
  // Were we already canceled?
  ct.ThrowIfCancellationRequested();
  // do some processing
});

タスクが実際に開始される前に呼び出しtokenSource.Cancel()が発行された場合でも、スレッドプールからワーカースレッドを割り当てるため、システムリソースの一部を浪費することになります。

ただし、でトークン引数を指定するTask.Factory.StartNewと、ワーカースレッドを割り当てずに、タスクがすぐにキャンセルされます。

于 2012-05-04T06:53:28.213 に答える
3

タスクとのキャンセルは引き続き協調的です。重要な操作の途中でスレッドが強制終了されることは望ましくありません。それを確認する必要があります。

ManualResetEventCancellationTokens は、カスケードまたは結合できるため、操作のシャットダウンを通知するための のような単純な構成体よりも優れています。タスクは 1 つCancellationTokenだけを参照する必要がありますが、いずれかからキャンセルできますCancellationTokenSource

于 2010-09-11T04:27:09.627 に答える