Rumah  >  Artikel  >  pembangunan bahagian belakang  >  Pelaksanaan tugas serentak di Golang dan Go WaitGroup

Pelaksanaan tugas serentak di Golang dan Go WaitGroup

PHPz
PHPzasal
2023-09-27 22:04:451289semak imbas

Golang中的任务并发执行和Go WaitGroup

Pelaksanaan tugas serentak di Golang dan Go WaitGroup

Di Golang, pelaksanaan tugas serentak adalah sangat penting. Dengan melaksanakan tugas secara serentak, anda boleh meningkatkan kecekapan dan responsif program anda. Golang menyediakan beberapa ciri yang menjadikan pelaksanaan tugasan serentak mudah dan cekap. Salah satu ciri penting ialah Go WaitGroup.

Go WaitGroup ialah primitif penyegerakan di Golang, digunakan untuk menunggu sekumpulan goroutin untuk menyelesaikan pelaksanaan. Ia memastikan kod menunggu tidak keluar awal sebelum semua coroutine selesai melaksanakan. Gunakan WaitGroup untuk mengelakkan tamat program sebelum pelaksanaan coroutine selesai.

Seterusnya kami akan menggunakan contoh khusus untuk menunjukkan pelaksanaan tugasan serentak dan penggunaan Go WaitGroup.

Pertama, kami mencipta fungsi tugasan untuk mensimulasikan beberapa operasi yang memakan masa. Fungsi ini akan menerima nombor tugasan sebagai parameter dan mencetak nombor tugasan dan mesej penyempurnaan pelaksanaan:

func simulateTask(taskNum int) {
    time.Sleep(time.Duration(rand.Intn(3)) * time.Second)
    fmt.Printf("Task %d is complete
", taskNum)
}

Seterusnya, kami mencipta fungsi utama, mencipta satu set tugasan dalam fungsi ini, dan Gunakan Go WaitGroup untuk menunggu selesai semua tugasan:

func main() {
    var wg sync.WaitGroup // 创建一个WaitGroup
    tasks := 10 // 设定任务数量

    for i := 0; i < tasks; i++ {
        wg.Add(1) // 增加WaitGroup的计数器
        go func(taskNum int) {
            defer wg.Done() // 减少WaitGroup的计数器
            simulateTask(taskNum) // 执行任务
        }(i)
    }

    wg.Wait() // 等待所有任务完成

    fmt.Println("All tasks are completed")
}

Dalam contoh ini, kita mula-mula mencipta objek WaitGroup dan kemudian menetapkan bilangan tugasan untuk dilaksanakan. Dalam gelung tugas, kami menggunakan wg.Add(1) untuk meningkatkan pembilang WaitGroup, menunjukkan bahawa terdapat tugas yang perlu menunggu untuk disiapkan. Kami kemudian mencipta fungsi tanpa nama menggunakan kata kunci go di mana kami melaksanakan tugas sebenar dan memanggil wg.Done() untuk mengurangkan kaunter WaitGroup apabila tugasan selesai. Akhir sekali, tunggu semua tugasan selesai melalui pernyataan wg.Wait().

Dengan menjalankan program ini, kita dapat melihat pelaksanaan tugas serentak dan kesan Go WaitGroup. Setiap tugasan akan menunggu untuk tempoh masa rawak untuk menyelesaikan pelaksanaan dan mencetak mesej penyelesaian yang sepadan. Akhirnya, apabila semua tugas selesai, program mencetak mesej "Semua tugas telah selesai".

Contoh ini menunjukkan pelaksanaan tugasan serentak di Golang dan penggunaan Go WaitGroup. Dengan menggunakan mekanisme konkurensi dan menunggu secara rasional, kecekapan dan prestasi program boleh dipertingkatkan. Menggunakan ciri konkurensi yang berkuasa Golang, kami boleh menulis program serentak yang cekap dan berskala.

Ringkasnya, pelaksanaan tugas serentak dan Go WaitGroup di Golang ialah alat penting untuk mencapai keselarasan. Dengan menggunakan mekanisme konkurensi dengan betul, kami boleh menggunakan sepenuhnya keupayaan pemproses berbilang teras dan meningkatkan prestasi dan responsif program. Pada masa yang sama, melalui fungsi menunggu WaitGroup, kami boleh memastikan bahawa program tidak akan keluar awal sebelum semua tugasan selesai. Go WaitGroup ialah alat yang sangat berguna untuk situasi di mana anda perlu melaksanakan sejumlah besar tugas dan perlu menunggu semuanya selesai.

Saya berharap melalui contoh ini, pembaca dapat memahami konsep asas dan penggunaan pelaksanaan tugas serentak dan Go WaitGroup, dan menerapkannya secara fleksibel dalam projek sebenar.

Atas ialah kandungan terperinci Pelaksanaan tugas serentak di Golang dan Go WaitGroup. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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