


Cara selamat untuk menamatkan goroutine gelung tak terhingga?
Saya mempunyai goroutine yang bertindak sebagai pendengar. Strim input masuk ke dalam beberapa buffer channel
,我希望我的 goroutine 处理传入该通道的数据。然而,有时 channel
可能会暂时没有数据输入。如果 channel
yang tiada apa-apa untuk ditawarkan seketika dan saya mahu goroutine saya melakukan sesuatu yang berbeza. Fungsinya kelihatan seperti ini:
func main () { var wg sync.WaitGroup arr := make([]*myObject, 0) wg.Add(1) go listener(c, arr, &wg) for { // sending stuff to c } } func listener(c chan *myObject, arr []*myObject, wg *sync.WaitGroup) { for { select { case value := <- c: arr = append(arr, value) case <- time.After(1 * time.Second): fmt.Println(arr) } }
Masalahnya ialah saya mahu melihat semua yang melalui saluran itu dicetak. Jika kedudukan main
突然结束,可能 arr
中还剩下一些东西还没有打印出来,我就看不到了。所以我需要确保这个goroutine在程序结束之前处理完通道中的所有数据。我认为,这意味着我需要使用 WaitGroup
并使用 Wait()
来确保程序在我的 goroutine 完成需要执行的操作之前不会关闭。 但我不知道在我的 WaitGroup
上调用 Done()
.
Pada asasnya, saya memerlukan cara selamat untuk "menjeda" goroutine sebelum program tamat, dan mencetak apa yang tinggal. Bagaimana saya boleh melakukan ini?
Untuk memburukkan lagi keadaan, untuk perkara seperti ujian unit, saya menghantar data ke saluran sendiri dan selepas menghantar jumlah tertentu, saya ingin melihat tatasusunan. Walau bagaimanapun, jika saya hanya menyemak tatasusunan sejurus selepas kod yang menghantar data ke saluran, goroutine mungkin belum mempunyai peluang untuk memproses semua data lagi. Dalam kes ini, saya mahu menunggu goroutine memproses semua data yang saya hantar, dan kemudian saya mahu menjedanya dan memintanya untuk menunjukkan kepada saya tatasusunan. Tetapi bagaimana saya tahu apabila goroutine telah selesai diproses? Saya boleh sleep
tunggu sebentar, beri peluang untuk menyelesaikannya, dan kemudian berhenti dan lihat, tetapi rasanya agak meretas. Saya rasa ada cara amalan terbaik untuk menyelesaikan masalah ini, tetapi saya masih belum mengetahuinya.
Berikut adalah beberapa idea yang saya ada, sifar daripadanya berkesan.
dalam infiniti
for
循环之外调用Done()
. Ini tidak berfungsi kerana sejauh yang saya tahu kod itu tidak boleh diakses.Dalam tamat masa
case
中调用Done()
. Ini tidak berfungsi kerana selepas tamat masa mungkin terdapat lebih banyak data dalam perjalanan dan saya mahu goroutine saya terus mendengar.
Jawapan betul
Ubah suai pendengar untuk kembali apabila saluran ditutup. Panggil wg.Done() apabila kembali:
func listener(c chan *myObject, arr []*myObject, wg *sync.WaitGroup) { defer wg.Done() for { select { case value, ok := <- c: if !ok { return } arr = append(arr, value) case <- time.After(1 * time.Second): fmt.Println(arr) } }
Ubah suai utama untuk menutup saluran selepas penghantaran selesai. Tunggu goroutine selesai sebelum pulang dari utama.
var wg sync.WaitGroup arr := make([]*myObject, 0) wg.Add(1) go listener(c, arr, &wg) for { // sending stuff to c } close(c) wg.Wait()
Atas ialah kandungan terperinci Cara selamat untuk menamatkan goroutine gelung tak terhingga?. 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

AI Hentai Generator
Menjana ai hentai secara percuma.

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



Artikel ini menerangkan cara menggunakan alat PPROF untuk menganalisis prestasi GO, termasuk membolehkan profil, mengumpul data, dan mengenal pasti kesesakan biasa seperti CPU dan isu memori.

Artikel ini membincangkan ujian unit menulis di GO, meliputi amalan terbaik, teknik mengejek, dan alat untuk pengurusan ujian yang cekap.

Artikel ini menunjukkan penciptaan dan stub di GO untuk ujian unit. Ia menekankan penggunaan antara muka, menyediakan contoh pelaksanaan mengejek, dan membincangkan amalan terbaik seperti menjaga mocks fokus dan menggunakan perpustakaan penegasan. Articl

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.

Artikel ini meneroka kekangan jenis adat Go untuk generik. Ia memperincikan bagaimana antara muka menentukan keperluan jenis minimum untuk fungsi generik, meningkatkan keselamatan jenis dan kebolehgunaan semula kod. Artikel ini juga membincangkan batasan dan amalan terbaik

Artikel ini membincangkan pakej GO's Reflect, yang digunakan untuk manipulasi kod runtime, bermanfaat untuk siri, pengaturcaraan generik, dan banyak lagi. Ia memberi amaran tentang kos prestasi seperti pelaksanaan yang lebih perlahan dan penggunaan memori yang lebih tinggi, menasihati penggunaan yang bijak dan terbaik

Artikel ini membincangkan menggunakan ujian yang didorong oleh jadual di GO, satu kaedah yang menggunakan jadual kes ujian untuk menguji fungsi dengan pelbagai input dan hasil. Ia menyoroti faedah seperti kebolehbacaan yang lebih baik, penurunan duplikasi, skalabiliti, konsistensi, dan a

Artikel ini meneroka menggunakan alat pengesanan untuk menganalisis aliran pelaksanaan aplikasi GO. Ia membincangkan teknik instrumentasi manual dan automatik, membandingkan alat seperti Jaeger, Zipkin, dan OpenTelemetry, dan menonjolkan visualisasi data yang berkesan
