


Cara menggunakan Goroutines untuk mengendalikan tugas tak segerak dalam bahasa Go
Cara menggunakan Goroutines untuk mengendalikan tugas tak segerak dalam bahasa Go
Abstrak: Goroutines ialah utas ringan dalam bahasa Go yang boleh melaksanakan pelaksanaan tugasan serentak. Artikel ini akan memperkenalkan penggunaan asas Goroutines dan menggabungkannya dengan contoh kod untuk menggambarkan cara menggunakan Goroutines untuk mengendalikan tugas tak segerak dalam bahasa Go.
Pengenalan:
Dengan pembangunan perkakasan komputer dan populariti pemproses berbilang teras, pembangun selalunya perlu memproses tugasan secara selari untuk meningkatkan prestasi program. Dalam model benang tradisional, overhed yang disebabkan oleh penciptaan dan penukaran benang sering menjadi kesesakan pemprosesan serentak. Sebaliknya, kemunculan Goroutines telah sangat memudahkan pengaturcaraan serentak, membolehkan pembangun mencipta Goroutines ringan untuk mencapai pemprosesan tugas serentak tinggi.
1. Penggunaan asas Goroutines
Dalam bahasa Go, anda boleh mencipta Goroutine dengan menggunakan kata kunci "go". Setiap kali fungsi dipanggil, kata kunci "go" boleh ditambah di hadapan fungsi untuk menunjukkan bahawa fungsi itu akan dilaksanakan dalam bentuk Goroutine.
Contohnya:
func main() { go func() { // 这里是任务的执行逻辑 }() // 其他的代码逻辑 }
Kuncinya terletak pada penggunaan kata kunci "go", yang membolehkan fungsi untuk tidak menyekat pelaksanaan utas utama apabila dipanggil, tetapi untuk kembali serta-merta. Dalam Goroutine, sebarang pernyataan Go yang sah boleh dilaksanakan, termasuk memanggil fungsi lain, melakukan pengiraan, mengakses data kongsi, dsb. Apabila tugas dalam Goroutine selesai, ia akan keluar secara automatik.
2. Contoh Goroutines memproses tugas tak segerak
Dalam pembangunan sebenar, kita selalunya perlu mengendalikan beberapa tugas tak segerak yang memakan masa, seperti permintaan rangkaian, membaca dan menulis fail, operasi pangkalan data, dsb. Menggunakan Goroutines boleh meningkatkan keupayaan pemprosesan serentak tugas-tugas ini dengan berkesan.
Yang berikut menggunakan contoh bacaan fail untuk menggambarkan cara menggunakan Goroutines untuk mengendalikan tugas tak segerak.
package main import ( "fmt" "io/ioutil" "sync" ) func readFromFile(filename string, wg *sync.WaitGroup) { defer wg.Done() data, err := ioutil.ReadFile(filename) if err != nil { fmt.Printf("读取文件 %s 失败:%v ", filename, err) return } fmt.Printf("文件 %s 的内容:%s ", filename, data) } func main() { var wg sync.WaitGroup wg.Add(2) go readFromFile("file1.txt", &wg) go readFromFile("file2.txt", &wg) wg.Wait() }
Dalam contoh kod di atas, kami menentukan fungsi readFromFile untuk membaca kandungan fail. Dalam fungsi utama, kami menetapkan bilangan Goroutine untuk menunggu dengan memanggil "wg.Add(2)". Apabila memulakan Goroutine, kami menghantar &wg sebagai parameter kepada fungsi readFromFile untuk memberitahu urutan utama apabila tugasan selesai.
Dalam fungsi readFromFile, kami menggunakan defer wg.Done() untuk memberitahu urutan utama bahawa tugasan telah selesai. Apabila kedua-dua Goroutine telah menyelesaikan tugas mereka, utas utama boleh menunggu untuk selesai dengan memanggil wg.Wait().
3. Kesimpulan
Artikel ini memperkenalkan penggunaan asas Goroutines dan cara mengendalikan tugas tak segerak melalui Goroutines. Berbanding dengan model benang tradisional, menggunakan Goroutines boleh membawa pemprosesan serentak yang lebih ringan, meningkatkan prestasi program. Dalam pembangunan sebenar, kami secara munasabah boleh menggunakan Goroutines untuk mengendalikan pelbagai jenis tugas mengikut keperluan khusus untuk mencapai pemprosesan serentak yang cekap.
Rujukan:
[1] Spesifikasi Bahasa Pengaturcaraan Go, https://golang.org/ref/spec
[2] The Go Blog, https://blog.golang.org/
[3] Go by Example , https://gobyexample.com/
[4] Go Concurrency Patterns, https://talks.golang.org/2012/concurrency.slide
Nota: Kod di atas adalah untuk rujukan sahaja dan mungkin perlu dilaraskan mengikut kepada keadaan dan pengubahsuaian tertentu.
Atas ialah kandungan terperinci Cara menggunakan Goroutines untuk mengendalikan tugas tak segerak 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, ...

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

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

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

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