


Pengaturcaraan serentak yang cekap: menggunakan Go WaitGroup dan kumpulan coroutine
Pengaturcaraan Serentak yang Cekap: Menggunakan Go WaitGroup dan Coroutine Pool
Pengenalan:
Dalam sistem komputer moden, pengaturcaraan serentak menjadi semakin penting. Pengaturcaraan serentak boleh memaksimumkan penggunaan prestasi pemproses berbilang teras dan meningkatkan kecekapan pelaksanaan program. Walau bagaimanapun, pengaturcaraan serentak juga menghadapi cabaran, seperti menangani penyegerakan dan pengurusan tugas serentak. Dalam artikel ini, kami akan memperkenalkan cara menggunakan WaitGroup dan kumpulan coroutine dalam bahasa Go untuk mencapai pengaturcaraan serentak yang cekap dan menyediakan contoh kod khusus.
1. Penggunaan WaitGroup:
Bahasa Go menyediakan jenis WaitGroup yang sangat berguna, yang boleh digunakan untuk menunggu sekumpulan coroutine menyelesaikan pelaksanaan. Berikut ialah contoh mudah yang menunjukkan cara menggunakan WaitGroup untuk mencapai penyegerakan tugasan serentak:
package main import ( "fmt" "sync" ) func worker(id int, wg *sync.WaitGroup) { defer wg.Done() fmt.Printf("Worker %d starting ", id) // 模拟耗时的任务 for i := 0; i < 5; i++ { fmt.Printf("Worker %d: %d ", id, i) } fmt.Printf("Worker %d done ", id) } func main() { var wg sync.WaitGroup // 启动5个协程 for i := 0; i < 5; i++ { wg.Add(1) go worker(i, &wg) } // 等待所有协程执行完毕 wg.Wait() }
Dalam kod di atas, kami mentakrifkan fungsi pekerja untuk mensimulasikan tugas yang memakan masa. Kami memberitahu WaitGroup bahawa tugas telah selesai dengan menghantar penunjuk ke WaitGroup. Dalam fungsi utama, kami memulakan 5 coroutine dan memaklumkan WaitGroup untuk menambah bilangan tugas menunggu dengan memanggil kaedah wg.Add(1)
. Akhir sekali, kami memanggil kaedah wg.Wait()
untuk menyekat coroutine utama sehingga semua tugasan selesai. wg.Add(1)
方法来通知WaitGroup等待的任务数量加一。最后,我们调用wg.Wait()
方法来阻塞主协程,直到所有的任务都完成。
二、协程池的使用:
Go语言还提供了协程池的实现,用于限制并发的数量,防止同时运行太多的协程。协程池可以帮助我们平衡系统的资源,并避免资源浪费。下面是一个示例,展示了如何使用协程池来执行任务:
package main import ( "fmt" "sync" ) type Pool struct { workers chan struct{} wg sync.WaitGroup } func NewPool(size int) *Pool { return &Pool{ workers: make(chan struct{}, size), } } func (p *Pool) AddTask(task func()) { p.workers <- struct{}{} p.wg.Add(1) go func() { task() <-p.workers p.wg.Done() }() } func (p *Pool) Wait() { p.wg.Wait() } func main() { pool := NewPool(3) // 添加10个任务到协程池 for i := 0; i < 10; i++ { taskID := i pool.AddTask(func() { fmt.Printf("Task %d is running ", taskID) }) } // 等待所有任务完成 pool.Wait() }
在上述代码中,我们定义了一个Pool结构体,其中包含一个用于限制协程数量的workers通道和一个WaitGroup用于等待所有任务完成。我们通过调用p.workers <- struct{}{}
往通道中写入一个空结构体,表示有一个协程正在执行任务;通过<-p.workers
从通道中取出一个空结构体,表示一个协程执行完了任务。在AddTask方法中,我们将任务添加到协程池中,并在任务执行完成后从通道中取出一个空结构体。最后,调用pool.Wait()
Bahasa Go juga menyediakan pelaksanaan kumpulan coroutine, yang digunakan untuk mengehadkan bilangan concurrency dan menghalang terlalu banyak coroutine daripada berjalan pada masa yang sama. Kumpulan coroutine boleh membantu kami mengimbangi sumber sistem dan mengelakkan pembaziran sumber. Berikut ialah contoh yang menunjukkan cara menggunakan kumpulan coroutine untuk melaksanakan tugas:
rrreee
p.workers <- struct{}{}
, menunjukkan bahawa coroutine sedang melaksanakan tugas dengan memanggil <-p.workers Alih keluar struktur kosong daripada saluran, menunjukkan bahawa coroutine telah menyelesaikan tugasnya. Dalam kaedah AddTask, kami menambah tugas pada kumpulan coroutine dan mengeluarkan struktur kosong daripada saluran selepas pelaksanaan tugas selesai. Akhir sekali, panggil kaedah pool.Wait()
untuk menunggu semua tugasan selesai. 🎜🎜Kesimpulan: 🎜Dengan menggunakan WaitGroup dan kumpulan coroutine, kami boleh mencapai pengaturcaraan serentak yang cekap dengan mudah. WaitGroup membantu kami menyegerakkan pelaksanaan tugas serentak, manakala kumpulan coroutine mengehadkan bilangan konkurensi dan meningkatkan penggunaan sumber sistem. Dalam aplikasi sebenar, kita boleh melaraskan saiz kolam coroutine mengikut keperluan untuk menggunakan sepenuhnya prestasi komputer. 🎜
Atas ialah kandungan terperinci Pengaturcaraan serentak yang cekap: menggunakan Go WaitGroup dan kumpulan coroutine. 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





Dalam pengaturcaraan serentak C++, reka bentuk struktur data yang selamat serentak adalah penting: Bahagian kritikal: Gunakan kunci mutex untuk mencipta blok kod yang membenarkan hanya satu utas untuk dilaksanakan pada masa yang sama. Kunci baca-tulis: membenarkan beberapa utas dibaca pada masa yang sama, tetapi hanya satu utas untuk ditulis pada masa yang sama. Struktur data tanpa kunci: Gunakan operasi atom untuk mencapai keselamatan serentak tanpa kunci. Kes praktikal: Barisan selamat benang: Gunakan bahagian kritikal untuk melindungi operasi baris gilir dan mencapai keselamatan benang.

Dalam Go, mesej WebSocket boleh dihantar menggunakan pakej gorila/soket web. Langkah khusus: Wujudkan sambungan WebSocket. Hantar mesej teks: Panggil WriteMessage(websocket.TextMessage,[]bait("Mesej")). Hantar mesej binari: panggil WriteMessage(websocket.BinaryMessage,[]bait{1,2,3}).

Dalam Go, anda boleh menggunakan ungkapan biasa untuk memadankan cap masa: susun rentetan ungkapan biasa, seperti yang digunakan untuk memadankan cap masa ISO8601: ^\d{4}-\d{2}-\d{2}T \d{ 2}:\d{2}:\d{2}(\.\d+)?(Z|[+-][0-9]{2}:[0-9]{2})$ . Gunakan fungsi regexp.MatchString untuk menyemak sama ada rentetan sepadan dengan ungkapan biasa.

Bahasa Go dan Go adalah entiti yang berbeza dengan ciri yang berbeza. Go (juga dikenali sebagai Golang) terkenal dengan kesesuaiannya, kelajuan penyusunan pantas, pengurusan memori dan kelebihan merentas platform. Kelemahan bahasa Go termasuk ekosistem yang kurang kaya berbanding bahasa lain, sintaks yang lebih ketat dan kekurangan penaipan dinamik.

Dalam pengaturcaraan berbilang benang C++, peranan primitif penyegerakan adalah untuk memastikan ketepatan berbilang utas yang mengakses sumber yang dikongsi Ia termasuk: Mutex (Mutex): melindungi sumber yang dikongsi dan menghalang akses serentak (ConditionVariable): thread Tunggu khusus syarat yang perlu dipenuhi sebelum meneruskan operasi atom: memastikan bahawa operasi dilaksanakan dengan cara yang tidak terganggu.

Kebocoran memori boleh menyebabkan memori program Go terus meningkat dengan: menutup sumber yang tidak lagi digunakan, seperti fail, sambungan rangkaian dan sambungan pangkalan data. Gunakan rujukan yang lemah untuk mengelakkan kebocoran memori dan objek sasaran untuk pengumpulan sampah apabila ia tidak lagi dirujuk dengan kuat. Menggunakan go coroutine, memori tindanan coroutine akan dikeluarkan secara automatik apabila keluar untuk mengelakkan kebocoran memori.

Apabila menghantar peta ke fungsi dalam Go, salinan akan dibuat secara lalai dan pengubahsuaian pada salinan tidak akan menjejaskan peta asal. Jika anda perlu mengubah suai peta asal, anda boleh menghantarnya melalui penuding. Peta kosong perlu dikendalikan dengan berhati-hati, kerana ia secara teknikal adalah penunjuk sifar, dan menghantar peta kosong kepada fungsi yang menjangkakan peta tidak kosong akan menyebabkan ralat.

Dalam Golang, pembalut ralat membolehkan anda membuat ralat baharu dengan menambahkan maklumat kontekstual kepada ralat asal. Ini boleh digunakan untuk menyatukan jenis ralat yang dilemparkan oleh perpustakaan atau komponen yang berbeza, memudahkan penyahpepijatan dan pengendalian ralat. Langkah-langkahnya adalah seperti berikut: Gunakan fungsi ralat. Balut untuk membalut ralat asal kepada ralat baharu. Ralat baharu mengandungi maklumat kontekstual daripada ralat asal. Gunakan fmt.Printf untuk mengeluarkan ralat yang dibalut, memberikan lebih konteks dan kebolehtindakan. Apabila mengendalikan pelbagai jenis ralat, gunakan fungsi ralat. Balut untuk menyatukan jenis ralat.
