Rumah pembangunan bahagian belakang Golang Bagaimana untuk serentak data dalam golang

Bagaimana untuk serentak data dalam golang

May 12, 2023 pm 08:50 PM

Bahasa Go ialah bahasa yang direka dengan pengaturcaraan serentak sebagai fokusnya. Ia mempunyai benang ringan (iaitu goroutine) dan mekanisme komunikasi yang boleh dilanjutkan, menjadikannya sangat cekap apabila memproses data serentak. Artikel ini akan memperkenalkan cara menggunakan goroutin dan saluran untuk melaksanakan pemprosesan data serentak dalam Go.

Groutine ialah benang ringan yang diuruskan oleh sistem masa jalan Go. Tidak seperti model benang tradisional, goroutin dicipta dan dimusnahkan dengan sangat cepat dan membenarkan pembangun menjalankan beribu-ribu gorouti pada masa yang sama, yang menjadikan Go sangat sesuai untuk memproses data serentak.

Untuk mencipta goroutine, kita boleh menggunakan kata kunci go, contohnya:

go func() {
    // goroutine的执行代码
}()

Apabila menggunakan kata kunci go, kami akan melaksanakan fungsi tanpa nama dalam goroutine baharu. Fungsi ini boleh mengakses pembolehubah dalam skop semasa, jadi ia sangat mudah apabila menulis kod tak segerak.

Malah, proses penggunaan goroutine untuk memproses data serentak adalah serupa dengan proses menggunakan fungsi biasa untuk memproses data. Sebagai contoh, katakan kita mempunyai kepingan jenis int yang mengandungi 100 elemen dan kita ingin menambah 1 pada semua elemennya dan mengira jumlahnya, kita boleh menulis seperti ini:

func main() {
    nums := []int{1, 2, 3, ..., 100}
    sum := 0
    for _, num := range nums {
        go func(n int) {
            sum += n + 1
        }(num)
    }
    time.Sleep(time.Second) // 等待所有goroutine完成
    fmt.Println(sum) // 输出10100
}

Dalam kod di atas, kita akan Mulakan goroutine untuk setiap elemen dan tambah 1 padanya, kemudian tambah keputusan untuk mengira jumlahnya. Perlu diingatkan bahawa memandangkan goroutin dilaksanakan secara tidak segerak, kita perlu menggunakan time.Sleep untuk menunggu semua goroutin selesai.

Memanggil goroutine di dalam kaedah menghasilkan goroutine baharu pada tindanan panggilan yang berkongsi timbunan dan tindanan dengan goroutine asal dan mempunyai akses kepada pembolehubah yang sama. Pendekatan konkurensi ini membolehkan kami memproses data secara serentak dengan cekap. Walau bagaimanapun, adalah penting untuk ambil perhatian bahawa memandangkan pembolehubah yang dikongsi boleh menyebabkan perlumbaan data, kita mesti memastikan akses serentak kepada pembolehubah yang dikongsi disegerakkan.

Untuk menyelesaikan masalah ini, Go menyediakan saluran. Saluran ialah mekanisme penyegerakan yang membenarkan gorouti menghantar dan menerima data dengan selamat antara gorouti. Kita boleh menggunakan fungsi make untuk mencipta saluran, contohnya:

ch := make(chan int)

Ini akan mencipta saluran dengan jenis int dan kita boleh meletakkan beberapa nilai dalam cachenya, atau menghantar dan menerima nilai.

Untuk menghantar data ke saluran, gunakan operator <-:

ch <- 1 // 将1发送到通道

Untuk menerima data, anda boleh menggunakan operator <-, contohnya:

x := <-ch // 从通道中接收一个值,并将其赋值给x

Operasi saluran adalah menyekat, ini Maksudnya jika kita cuba menerima data dari saluran kosong, program akan disekat sehingga ada data yang boleh dihantar. Begitu juga, jika kita cuba menghantar data ke saluran yang penuh, program akan disekat sehingga goroutine lain boleh menerima data tersebut.

Kami boleh menggunakan saluran untuk menyegerakkan data antara goroutine. Sebagai contoh, katakan kita mempunyai saluran yang menerima dua nombor daripada saluran setiap kali dan menambahnya bersama-sama. Berikut ialah contoh mudah:

func sum(ch chan int, nums ...int) {
    for _, n := range nums {
        ch <- n
    }
    close(ch)
}

func main() {
    ch := make(chan int)
    go sum(ch, 1, 2, 3, 4, 5) // 将1,2,3,4,5发送到通道ch中

    sum := 0
    for n := range ch {
        sum += n
    }
    fmt.Println(sum) // 输出15
}

Dalam contoh di atas, kami mula-mula mencipta saluran ch dan memulakan goroutine fungsi sum yang menerima sebarang nombor dan meletakkan Ia dihantar ke saluran. Kemudian, dalam fungsi utama, kami menggunakan gelung mudah untuk membaca data daripada saluran dan menambahkannya bersama-sama.

Perlu diambil perhatian bahawa operasi saluran disekat, jadi beri perhatian khusus kepada isu kebuntuan apabila menggunakan saluran. Jika kami menghantar data ke saluran yang ditutup sebelum membaca data, atau membaca data daripada saluran yang sudah kosong, program akan menyekat dan tidak akan keluar.

Ringkasnya, model konkurensi bahasa Go sangat sesuai untuk memproses data serentak, dan pemprosesan serentak yang cekap boleh dicapai dengan mudah menggunakan goroutin dan saluran. Walau bagaimanapun, apabila menggunakan model konkurensi, anda perlu berhati-hati terutamanya tentang perlumbaan data dan kebuntuan untuk memastikan ketepatan dan keberkesanan program.

Atas ialah kandungan terperinci Bagaimana untuk serentak data dalam golang. 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

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

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.

Stock Market GPT

Stock Market GPT

Penyelidikan pelaburan dikuasakan AI untuk keputusan yang lebih bijak

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)

Pergi antara muka: keperluan di bawah pelaksanaan yang tidak dipaksa Pergi antara muka: keperluan di bawah pelaksanaan yang tidak dipaksa Sep 09, 2025 am 11:09 AM

Walaupun antara muka GO tidak memaksa pelaksanaan pengisytiharan yang jelas, mereka masih penting dalam melaksanakan polimorfisme dan decoupling kod. Dengan menentukan satu set tandatangan kaedah, antara muka membolehkan jenis yang berbeza diproses dengan cara bersatu, membolehkan reka bentuk dan skalabiliti kod fleksibel. Artikel ini akan meneroka ciri -ciri antara muka Go secara mendalam dan menunjukkan nilai aplikasinya dalam pembangunan sebenar melalui contoh.

Bagaimana untuk menentukan fail yang terlibat dalam penyusunan semasa membina? Bagaimana untuk menentukan fail yang terlibat dalam penyusunan semasa membina? Sep 09, 2025 am 11:57 AM

Artikel ini bertujuan untuk membantu pemaju memahami bagaimana untuk menentukan fail mana yang akan disusun dan dihubungkan dalam projek GO, terutamanya jika fail khusus sistem wujud. Kami akan meneroka dua kaedah: menghuraikan output menggunakan arahan Go Build -n, dan menggunakan fungsi import pakej Go/Build. Dengan kaedah ini, anda boleh mempunyai pemahaman yang jelas tentang proses membina dan menguruskan projek anda dengan lebih baik.

Mulakan editor luaran dalam program Go dan tunggu selesai Mulakan editor luaran dalam program Go dan tunggu selesai Sep 16, 2025 pm 12:21 PM

Artikel ini menerangkan bagaimana untuk memulakan editor luaran (seperti VIM atau Nano) dalam program Go dan tunggu pengguna menutup editor sebelum program terus dilaksanakan. Dengan menetapkan cmd.stdin, cmd.stdout, dan cmd.stderr, editor boleh berinteraksi dengan terminal untuk menyelesaikan masalah kegagalan permulaan. Pada masa yang sama, contoh kod lengkap ditunjukkan dan langkah berjaga -jaga disediakan untuk membantu pemaju melaksanakan fungsi ini dengan lancar.

Bagaimana anda membaca dan menulis fail di Golang? Bagaimana anda membaca dan menulis fail di Golang? Sep 21, 2025 am 01:59 AM

Goprovidessimpleandefficientfilehandlingingtheosandbufiopackages.toreadasmallfileentirely, useos.readfile, whittloadsthecontentintomemorysafelyandautomatikManageSoperations.forlargefilesorincrementalprementalprementalprementrementprementalplocessing,

Apakah struct struktur kosong {} yang digunakan di Golang Apakah struct struktur kosong {} yang digunakan di Golang Sep 18, 2025 am 05:47 AM

Struct {} adalah struktur tanpa medan di GO, yang menduduki bait sifar dan sering digunakan dalam senario di mana data tidak diperlukan. Ia digunakan sebagai isyarat dalam saluran, seperti penyegerakan goroutine; 2. Digunakan sebagai koleksi jenis nilai peta untuk mencapai pemeriksaan kewujudan utama dalam ingatan yang cekap; 3. Penerima kaedah tanpa stateless yang pasti, sesuai untuk suntikan pergantungan atau fungsi organisasi. Jenis ini digunakan secara meluas untuk mengekspresikan aliran kawalan dan niat yang jelas.

Selesaikan GO WebSocket EOF ERROR: Pastikan sambungan aktif Selesaikan GO WebSocket EOF ERROR: Pastikan sambungan aktif Sep 16, 2025 pm 12:15 PM

Artikel ini bertujuan untuk menyelesaikan kesilapan EOF (akhir-of-file) yang dihadapi ketika membangunkan WebSocket menggunakan GO. Kesalahan ini biasanya berlaku apabila pelayan menerima mesej klien dan sambungannya ditutup tanpa disangka -sangka, mengakibatkan mesej berikutnya tidak dapat dihantar secara normal. Artikel ini akan menganalisis punca masalah, memberikan contoh kod, dan menyediakan penyelesaian yang sepadan untuk membantu pemaju membina aplikasi WebSocket yang stabil dan boleh dipercayai.

Apakah middleware dalam konteks pelayan web Golang? Apakah middleware dalam konteks pelayan web Golang? Sep 16, 2025 am 02:16 AM

MiddlewareinGowebserversarefunctionsthatinterceptHTTPrequestsbeforetheyreachthehandler,enablingreusablecross-cuttingfunctionality;theyworkbywrappinghandlerstoaddpre-andpost-processinglogicsuchaslogging,authentication,CORS,orerrorrecovery,andcanbechai

Cara Membaca Konfigurasi Dari Fail di Golang Cara Membaca Konfigurasi Dari Fail di Golang Sep 18, 2025 am 05:26 AM

Gunakan pakej pengekodan/json perpustakaan standard untuk membaca fail konfigurasi JSON; 2. Gunakan perpustakaan Gopkg.in/yaml.v3 untuk membaca konfigurasi format YAML; 3. Gunakan Perpustakaan OS.Getenv atau Godotenv untuk menimpa konfigurasi fail; 4. Gunakan perpustakaan Viper untuk menyokong fungsi lanjutan seperti konfigurasi pelbagai format, pembolehubah persekitaran, tambah nilai automatik; Adalah perlu untuk menentukan struktur untuk memastikan keselamatan jenis, mengendalikan kesilapan fail dan parsing dengan betul, menggunakan medan pemetaan tag struktur dengan betul, mengelakkan laluan berkod keras, dan mengesyorkan menggunakan pembolehubah persekitaran atau penyimpanan konfigurasi yang selamat dalam persekitaran pengeluaran. Ia boleh bermula dengan JSON yang mudah dan berhijrah ke Viper apabila keperluannya kompleks.

See all articles