


Bagaimana untuk menangani pembatalan tugas serentak dalam bahasa Go?
Bagaimana untuk menangani pembatalan tugas serentak dalam bahasa Go?
Sebagai bahasa pengaturcaraan serentak, bahasa Go menyediakan ciri pengaturcaraan serentak yang kaya, seperti goroutine dan saluran, menjadikannya sangat mudah untuk mengendalikan tugas serentak. Walau bagaimanapun, apabila ia datang untuk membatalkan tugas serentak, kami juga memerlukan mekanisme khas untuk memastikan keluar tugas dengan selamat. Artikel ini akan memperkenalkan cara mengendalikan pembatalan tugasan serentak dalam bahasa Go dan memberikan contoh kod khusus.
Dalam bahasa Go, kami biasanya menggunakan goroutine untuk melaksanakan tugas serentak. Goroutine ialah benang ringan yang boleh melaksanakan pelbagai tugas serentak untuk menggunakan sepenuhnya sumber pengkomputeran pada CPU berbilang teras. Kita boleh mencipta goroutine melalui kata kunci pergi, contohnya:
go func() { // 并发任务的逻辑代码 }()
Apabila kita mencipta berbilang goroutine untuk melaksanakan tugas secara serentak, kadangkala kita perlu secara aktif membatalkan pelaksanaan satu atau lebih tugas apabila syarat tertentu dipenuhi. Untuk mencapai fungsi ini, bahasa Go menyediakan mekanisme terbina dalam - konteks. Pakej konteks menyediakan mekanisme pembatalan untuk menghantar permintaan dan membantu kami menjejak dan membatalkan operasi dalam goroutine. Berikut ialah contoh kod tentang cara menggunakan konteks untuk membatalkan tugas:
package main import ( "context" "fmt" "time" ) func worker(ctx context.Context) { for { select { default: // 执行任务的逻辑代码 fmt.Println("正在执行任务...") time.Sleep(500 * time.Millisecond) case <-ctx.Done(): // 收到取消信号,退出goroutine fmt.Println("任务被取消") return } } } func main() { // 创建一个context对象和cancel函数 ctx, cancel := context.WithCancel(context.Background()) // 启动多个goroutine执行任务 for i := 0; i < 5; i++ { go worker(ctx) } // 延迟5秒后,取消任务 time.Sleep(5 * time.Second) cancel() // 等待所有goroutine退出 time.Sleep(1 * time.Second) fmt.Println("所有任务已完成") }
Dalam kod sampel di atas, kami menggunakan fungsi context.WithCancel untuk mencipta objek konteks boleh dibatalkan dan menghantar isyarat pembatalan melalui fungsi batal. Dalam fungsi pekerja, kami menggunakan pernyataan pilih untuk melaksanakan tugas dan membatalkan pemantauan. Jika isyarat pembatalan diterima, kami keluar dari goroutine. Dengan memanggil fungsi batal, kami boleh menyebarkan isyarat pembatalan kepada semua goroutin pekerja.
Menjalankan kod di atas, kita dapat melihat output seperti berikut:
正在执行任务... 正在执行任务... 正在执行任务... 任务被取消 任务被取消 任务被取消 任务被取消 任务被取消 所有任务已完成
Seperti yang dapat dilihat dari output, apabila kita memanggil fungsi batal, semua goroutine pekerja menerima isyarat pembatalan dan keluar dengan selamat.
Ringkasnya, bahasa Go menyediakan cara yang elegan untuk mengendalikan pembatalan tugasan serentak melalui mekanisme konteks. Kami hanya perlu mendengar mesej Selesai konteks semasa pelaksanaan tugasan Setelah isyarat pembatalan diterima, kami boleh keluar dari goroutine dengan selamat. Mekanisme ini menjadikan pembatalan tugas serentak lebih mudah dan lebih dipercayai, dan mengelak daripada memasukkan keadaan perlumbaan yang tidak perlu ke dalam aplikasi.
Di atas ialah pengenalan dan contoh kod tentang cara mengendalikan pembatalan tugas serentak dalam bahasa Go. Semoga ia membantu.
Atas ialah kandungan terperinci Bagaimana untuk menangani pembatalan tugas serentak dalam bahasa Go?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas





OpenSSL, sebagai perpustakaan sumber terbuka yang digunakan secara meluas dalam komunikasi yang selamat, menyediakan algoritma penyulitan, kunci dan fungsi pengurusan sijil. Walau bagaimanapun, terdapat beberapa kelemahan keselamatan yang diketahui dalam versi sejarahnya, yang sebahagiannya sangat berbahaya. Artikel ini akan memberi tumpuan kepada kelemahan umum dan langkah -langkah tindak balas untuk OpenSSL dalam sistem Debian. Debianopenssl yang dikenal pasti: OpenSSL telah mengalami beberapa kelemahan yang serius, seperti: Kerentanan Pendarahan Jantung (CVE-2014-0160): Kelemahan ini mempengaruhi OpenSSL 1.0.1 hingga 1.0.1f dan 1.0.2 hingga 1.0.2 versi beta. Penyerang boleh menggunakan kelemahan ini untuk maklumat sensitif baca yang tidak dibenarkan di pelayan, termasuk kunci penyulitan, dll.

Masalah Threading Giliran di GO Crawler Colly meneroka masalah menggunakan Perpustakaan Colly Crawler dalam bahasa Go, pemaju sering menghadapi masalah dengan benang dan permintaan beratur. � ...

Perpustakaan yang digunakan untuk operasi nombor terapung dalam bahasa Go memperkenalkan cara memastikan ketepatannya ...

Laluan Pembelajaran Backend: Perjalanan Eksplorasi dari Front-End ke Back-End sebagai pemula back-end yang berubah dari pembangunan front-end, anda sudah mempunyai asas Nodejs, ...

Perbezaan antara percetakan rentetan dalam bahasa Go: perbezaan kesan menggunakan fungsi println dan rentetan () sedang ...

Artikel ini memperkenalkan pelbagai kaedah dan alat untuk memantau pangkalan data PostgreSQL di bawah sistem Debian, membantu anda memahami pemantauan prestasi pangkalan data sepenuhnya. 1. Gunakan PostgreSQL untuk membina pemantauan PostgreSQL sendiri menyediakan pelbagai pandangan untuk pemantauan aktiviti pangkalan data: PG_STAT_ACTIVITY: Memaparkan aktiviti pangkalan data dalam masa nyata, termasuk sambungan, pertanyaan, urus niaga dan maklumat lain. PG_STAT_REPLITI: Memantau status replikasi, terutamanya sesuai untuk kluster replikasi aliran. PG_STAT_DATABASE: Menyediakan statistik pangkalan data, seperti saiz pangkalan data, masa komitmen/masa rollback transaksi dan petunjuk utama lain. 2. Gunakan alat analisis log pgbadg

Masalah menggunakan redisstream untuk melaksanakan beratur mesej dalam bahasa Go menggunakan bahasa Go dan redis ...

Di bawah rangka kerja beegoorm, bagaimana untuk menentukan pangkalan data yang berkaitan dengan model? Banyak projek beego memerlukan pelbagai pangkalan data untuk dikendalikan secara serentak. Semasa menggunakan beego ...
