Rumah pembangunan bahagian belakang Golang Bagaimana untuk menangani pembatalan tugas serentak dalam bahasa Go?

Bagaimana untuk menangani pembatalan tugas serentak dalam bahasa Go?

Oct 08, 2023 pm 01:36 PM
goroutinebatal panggilan konteks Pengurusan tugas serentak

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() {
  // 并发任务的逻辑代码
}()
Salin selepas log masuk

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("所有任务已完成")
}
Salin selepas log masuk

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:

正在执行任务...
正在执行任务...
正在执行任务...
任务被取消
任务被取消
任务被取消
任务被取消
任务被取消
所有任务已完成
Salin selepas log masuk

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!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

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

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Apakah kelemahan debian openssl Apakah kelemahan debian openssl Apr 02, 2025 am 07:30 AM

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.

Apakah masalah dengan thread giliran di crawler colly go? Apakah masalah dengan thread giliran di crawler colly go? Apr 02, 2025 pm 02:09 PM

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 apa yang digunakan untuk operasi nombor terapung di GO? Perpustakaan apa yang digunakan untuk operasi nombor terapung di GO? Apr 02, 2025 pm 02:06 PM

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

Berubah dari front-end ke pembangunan back-end, adakah lebih menjanjikan untuk belajar Java atau Golang? Berubah dari front-end ke pembangunan back-end, adakah lebih menjanjikan untuk belajar Java atau Golang? Apr 02, 2025 am 09:12 AM

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, ...

Di Go, mengapa rentetan percetakan dengan fungsi println dan rentetan () mempunyai kesan yang berbeza? Di Go, mengapa rentetan percetakan dengan fungsi println dan rentetan () mempunyai kesan yang berbeza? Apr 02, 2025 pm 02:03 PM

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

Kaedah Pemantauan PostgreSQL di bawah Debian Kaedah Pemantauan PostgreSQL di bawah Debian Apr 02, 2025 am 07:27 AM

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

Bagaimana menyelesaikan masalah penukaran jenis user_id semasa menggunakan aliran redis untuk melaksanakan beratur mesej dalam bahasa Go? Bagaimana menyelesaikan masalah penukaran jenis user_id semasa menggunakan aliran redis untuk melaksanakan beratur mesej dalam bahasa Go? Apr 02, 2025 pm 04:54 PM

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

Bagaimana cara menentukan pangkalan data yang berkaitan dengan model dalam beego orm? Bagaimana cara menentukan pangkalan data yang berkaitan dengan model dalam beego orm? Apr 02, 2025 pm 03:54 PM

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 ...

See all articles