Baca dalam bahasa Inggris

Bagikan melalui


CancellationTokenSource Kelas

Definisi

Sinyal ke CancellationToken bahwa itu harus dibatalkan.

C#
public class CancellationTokenSource : IDisposable
C#
[System.Runtime.InteropServices.ComVisible(false)]
public sealed class CancellationTokenSource : IDisposable
C#
[System.Runtime.InteropServices.ComVisible(false)]
public class CancellationTokenSource : IDisposable
Warisan
CancellationTokenSource
Atribut
Penerapan

Contoh

Contoh berikut menggunakan generator angka acak untuk meniru aplikasi pengumpulan data yang membaca 10 nilai integral dari sebelas instrumen yang berbeda. Nilai nol menunjukkan bahwa pengukuran telah gagal untuk satu instrumen, dalam hal ini operasi harus dibatalkan dan tidak ada rata-rata keseluruhan yang harus dihitung.

Untuk menangani kemungkinan pembatalan operasi, contoh membuat instans objek CancellationTokenSource yang menghasilkan token pembatalan yang diteruskan ke objek TaskFactory. Objek TaskFactory pada gilirannya meneruskan token pembatalan ke setiap tugas yang bertanggung jawab untuk mengumpulkan pembacaan untuk instrumen tertentu. Metode TaskFactory.ContinueWhenAll<TAntecedentResult,TResult>(Task<TAntecedentResult>[], Func<Task<TAntecedentResult>[],TResult>, CancellationToken) dipanggil untuk memastikan bahwa rata-rata dihitung hanya setelah semua pembacaan berhasil dikumpulkan. Jika tugas belum selesai karena telah dibatalkan, panggilan ke metode TaskFactory.ContinueWhenAll melemparkan pengecualian.

C#
using System;
using System.Collections.Generic;
using System.Threading;
using System.Threading.Tasks;

public class Example
{
   public static void Main()
   {
      // Define the cancellation token.
      CancellationTokenSource source = new CancellationTokenSource();
      CancellationToken token = source.Token;

      Random rnd = new Random();
      Object lockObj = new Object();
      
      List<Task<int[]>> tasks = new List<Task<int[]>>();
      TaskFactory factory = new TaskFactory(token);
      for (int taskCtr = 0; taskCtr <= 10; taskCtr++) {
         int iteration = taskCtr + 1;
         tasks.Add(factory.StartNew( () => {
           int value;
           int[] values = new int[10];
           for (int ctr = 1; ctr <= 10; ctr++) {
              lock (lockObj) {
                 value = rnd.Next(0,101);
              }
              if (value == 0) { 
                 source.Cancel();
                 Console.WriteLine("Cancelling at task {0}", iteration);
                 break;
              }   
              values[ctr-1] = value; 
           }
           return values;
        }, token));   
      }
      try {
         Task<double> fTask = factory.ContinueWhenAll(tasks.ToArray(), 
         (results) => {
            Console.WriteLine("Calculating overall mean...");
            long sum = 0;
            int n = 0; 
            foreach (var t in results) {
               foreach (var r in t.Result) {
                  sum += r;
                  n++;
               }
            }
            return sum/(double) n;
         } , token);
         Console.WriteLine("The mean is {0}.", fTask.Result);
      }   
      catch (AggregateException ae) {
         foreach (Exception e in ae.InnerExceptions) {
            if (e is TaskCanceledException)
               Console.WriteLine("Unable to compute mean: {0}", 
                  ((TaskCanceledException) e).Message);
            else
               Console.WriteLine("Exception: " + e.GetType().Name);
         }
      }
      finally {
         source.Dispose();
      }
   }
}
// Repeated execution of the example produces output like the following:
//       Cancelling at task 5
//       Unable to compute mean: A task was canceled.
//       
//       Cancelling at task 10
//       Unable to compute mean: A task was canceled.
//       
//       Calculating overall mean...
//       The mean is 5.29545454545455.
//       
//       Cancelling at task 4
//       Unable to compute mean: A task was canceled.
//       
//       Cancelling at task 5
//       Unable to compute mean: A task was canceled.
//       
//       Cancelling at task 6
//       Unable to compute mean: A task was canceled.
//       
//       Calculating overall mean...
//       The mean is 4.97363636363636.
//       
//       Cancelling at task 4
//       Unable to compute mean: A task was canceled.
//       
//       Cancelling at task 5
//       Unable to compute mean: A task was canceled.
//       
//       Cancelling at task 4
//       Unable to compute mean: A task was canceled.
//       
//       Calculating overall mean...
//       The mean is 4.86545454545455.

Keterangan

Dimulai dengan .NET Framework 4, .NET Framework menggunakan model terpadu untuk pembatalan kooperatif operasi sinkron asinkron atau jangka panjang yang melibatkan dua objek:

Pola umum untuk menerapkan model pembatalan koperasi adalah:

Untuk informasi selengkapnya, lihat Pembatalan di Utas Terkelola.

Penting

Jenis ini mengimplementasikan antarmuka IDisposable. Setelah selesai menggunakan instans jenis, Anda harus membuangnya baik secara langsung maupun tidak langsung. Untuk membuang jenis secara langsung, panggil metode Dispose dalam blok try/finally. Untuk membuangnya secara tidak langsung, gunakan konstruksi bahasa seperti using (dalam C#) atau Using (di Visual Basic). Untuk informasi selengkapnya, lihat bagian "Menggunakan Objek yang Menerapkan IDisposable" di topik antarmuka IDisposable.

Konstruktor

CancellationTokenSource()

Menginisialisasi instans baru kelas CancellationTokenSource.

CancellationTokenSource(Int32)

Menginisialisasi instans baru kelas CancellationTokenSource yang akan dibatalkan setelah penundaan yang ditentukan dalam milidetik.

CancellationTokenSource(TimeSpan)

Menginisialisasi instans baru kelas CancellationTokenSource yang akan dibatalkan setelah rentang waktu yang ditentukan.

CancellationTokenSource(TimeSpan, TimeProvider)

Menginisialisasi instans baru kelas CancellationTokenSource yang akan dibatalkan setelah TimeSpanyang ditentukan.

Properti

IsCancellationRequested

Mendapatkan apakah pembatalan telah diminta untuk CancellationTokenSourceini.

Token

Mendapatkan CancellationToken yang terkait dengan CancellationTokenSourceini.

Metode

Cancel()

Mengkomunikasikan permintaan pembatalan.

Cancel(Boolean)

Mengkomunikasikan permintaan pembatalan, dan menentukan apakah panggilan balik yang tersisa dan operasi yang dapat dibatalkan harus diproses jika terjadi pengecualian.

CancelAfter(Int32)

Menjadwalkan operasi pembatalan pada CancellationTokenSource ini setelah jumlah milidetik yang ditentukan.

CancelAfter(TimeSpan)

Menjadwalkan operasi pembatalan pada CancellationTokenSource ini setelah rentang waktu yang ditentukan.

CancelAsync()

Mengkomunikasikan permintaan pembatalan secara asinkron.

CreateLinkedTokenSource(CancellationToken)

Membuat CancellationTokenSource yang akan berada dalam status dibatalkan ketika token yang disediakan dalam status dibatalkan.

CreateLinkedTokenSource(CancellationToken, CancellationToken)

Membuat CancellationTokenSource yang akan berada dalam status dibatalkan ketika salah satu token sumber berada dalam status dibatalkan.

CreateLinkedTokenSource(CancellationToken[])

Membuat CancellationTokenSource yang akan berada dalam status dibatalkan ketika salah satu token sumber dalam array yang ditentukan berada dalam status dibatalkan.

CreateLinkedTokenSource(ReadOnlySpan<CancellationToken>)

Membuat CancellationTokenSource yang akan berada dalam status dibatalkan ketika salah satu token sumber berada dalam status dibatalkan.

Dispose()

Merilis semua sumber daya yang digunakan oleh instans kelas CancellationTokenSource saat ini.

Dispose(Boolean)

Merilis sumber daya yang tidak dikelola yang digunakan oleh kelas CancellationTokenSource dan secara opsional merilis sumber daya terkelola.

Equals(Object)

Menentukan apakah objek yang ditentukan sama dengan objek saat ini.

(Diperoleh dari Object)
GetHashCode()

Berfungsi sebagai fungsi hash default.

(Diperoleh dari Object)
GetType()

Mendapatkan Type instans saat ini.

(Diperoleh dari Object)
MemberwiseClone()

Membuat salinan dangkal dari Objectsaat ini.

(Diperoleh dari Object)
ToString()

Mengembalikan string yang mewakili objek saat ini.

(Diperoleh dari Object)
TryReset()

Mencoba mengatur ulang CancellationTokenSource yang akan digunakan untuk operasi yang tidak terkait.

Berlaku untuk

Produk Versi
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Keamanan Thread

Semua anggota CancellationTokenSource publik dan terlindungi aman utas dan dapat digunakan secara bersamaan dari beberapa utas, dengan pengecualian Dispose(), yang hanya boleh digunakan ketika semua operasi lain pada objek CancellationTokenSource telah selesai.

Lihat juga

  • Pembatalan
  • Pembatalan Tugas