Rumah pembangunan bahagian belakang Golang Bagaimana untuk melaksanakan corak pengeluar-pengguna menggunakan fungsi serentak dalam bahasa Go?

Bagaimana untuk melaksanakan corak pengeluar-pengguna menggunakan fungsi serentak dalam bahasa Go?

Jul 31, 2023 pm 06:30 PM
fungsi serentak pengeluar-pengguna

Bagaimana untuk melaksanakan corak pengeluar-pengguna menggunakan fungsi serentak dalam bahasa Go?

Dalam sains komputer, corak pengeluar-pengguna ialah corak reka bentuk konkurensi klasik. Ia melibatkan dua peranan utama: pengeluar bertanggungjawab untuk menjana data, dan pengguna bertanggungjawab untuk memproses data ini. Pengeluar dan pengguna berinteraksi melalui penimbal yang dikongsi Pengeluar meletakkan data ke dalam penimbal, dan pengguna mengeluarkan data daripada penimbal untuk diproses.

Dalam bahasa Go, kita boleh melaksanakan model pengeluar-pengguna melalui fungsi dan saluran serentak. Di bawah ialah contoh kod yang menunjukkan cara melaksanakan corak ini menggunakan bahasa Go.

package main

import (
    "fmt"
    "math/rand"
    "sync"
    "time"
)

// 缓冲区大小
const bufferSize = 5

// 生产者函数
func producer(buffer chan<- int, wg *sync.WaitGroup) {
    defer wg.Done()

    for i := 0; i < 10; i++ {
        value := rand.Intn(100) // 生成一个随机数作为数据
        buffer <- value        // 将数据放入缓冲区
        fmt.Println("Producer produces", value)
        time.Sleep(time.Millisecond * time.Duration(rand.Intn(500)))
    }

    close(buffer) // 关闭缓冲区
}

// 消费者函数
func consumer(buffer <-chan int, wg *sync.WaitGroup) {
    defer wg.Done()

    for value := range buffer {
        fmt.Println("Consumer consumes", value)
        time.Sleep(time.Millisecond * time.Duration(rand.Intn(1000)))
    }
}

func main() {
    buffer := make(chan int, bufferSize)
    var wg sync.WaitGroup

    wg.Add(2)

    go producer(buffer, &wg)
    go consumer(buffer, &wg)

    wg.Wait()
}
Salin selepas log masuk

Dalam kod di atas, kami mentakrifkan penimbal buffer,大小为 5。生产者函数 producer 生成随机数作为数据,并放入缓冲区中。消费者函数 consumer 从缓冲区中取出数据并进行处理。主函数使用 sync.WaitGroup untuk memastikan program tidak akan keluar sehingga fungsi pengeluar dan pengguna dilaksanakan.

Dengan menjalankan kod di atas, kita dapat melihat bahawa pengeluar terus menjana data dan memasukkannya ke dalam penimbal, manakala pengguna secara berterusan mengeluarkan data daripada penimbal untuk diproses. Oleh kerana saiz penimbal ialah 5, apabila penimbal penuh, pengeluar akan menyekat sehingga ada lokasi percuma. Begitu juga, apabila penimbal kosong, pengguna akan menyekat sehingga data tersedia.

Untuk meringkaskan, menggunakan fungsi dan saluran serentak dalam bahasa Go, kami boleh melaksanakan corak pengeluar-pengguna dengan mudah. Model ini membolehkan pengeluar dan pengguna bekerja secara serentak, meningkatkan daya pengeluaran dan responsif sistem. Dengan menetapkan saiz penimbal dengan sewajarnya, kami boleh mengawal kelajuan pengeluar dan pengguna untuk menyesuaikan diri dengan keperluan senario yang berbeza.

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan corak pengeluar-pengguna menggunakan fungsi serentak dalam bahasa Go?. 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

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.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

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)

Petua untuk mencipta fungsi baharu secara dinamik dalam fungsi golang Petua untuk mencipta fungsi baharu secara dinamik dalam fungsi golang Apr 25, 2024 pm 02:39 PM

Bahasa Go menyediakan dua teknologi penciptaan fungsi dinamik: penutupan dan refleksi. penutupan membenarkan akses kepada pembolehubah dalam skop penutupan, dan refleksi boleh mencipta fungsi baharu menggunakan fungsi FuncOf. Teknologi ini berguna dalam menyesuaikan penghala HTTP, melaksanakan sistem yang sangat boleh disesuaikan dan membina komponen boleh pasang.

Bagaimanakah concurrency dan multithreading fungsi Java boleh meningkatkan prestasi? Bagaimanakah concurrency dan multithreading fungsi Java boleh meningkatkan prestasi? Apr 26, 2024 pm 04:15 PM

Teknik concurrency dan multithreading menggunakan fungsi Java boleh meningkatkan prestasi aplikasi, termasuk langkah berikut: Memahami konsep concurrency dan multithreading. Manfaatkan pustaka konkurensi dan berbilang benang Java seperti ExecutorService dan Callable. Amalkan kes seperti pendaraban matriks berbilang benang untuk memendekkan masa pelaksanaan. Nikmati kelebihan peningkatan kelajuan tindak balas aplikasi dan kecekapan pemprosesan yang dioptimumkan yang dibawa oleh concurrency dan multi-threading.

Aplikasi konkurensi dan coroutine dalam reka bentuk API Golang Aplikasi konkurensi dan coroutine dalam reka bentuk API Golang May 07, 2024 pm 06:51 PM

Concurrency dan coroutine digunakan dalam reka bentuk GoAPI untuk: Pemprosesan berprestasi tinggi: Memproses berbilang permintaan serentak untuk meningkatkan prestasi. Pemprosesan tak segerak: Gunakan coroutine untuk memproses tugas (seperti menghantar e-mel) secara tidak segerak, melepaskan utas utama. Pemprosesan strim: Gunakan coroutine untuk memproses strim data dengan cekap (seperti bacaan pangkalan data).

Koleksi lengkap formula fungsi excel Koleksi lengkap formula fungsi excel May 07, 2024 pm 12:04 PM

1. Fungsi SUM digunakan untuk menjumlahkan nombor dalam lajur atau sekumpulan sel, contohnya: =SUM(A1:J10). 2. Fungsi AVERAGE digunakan untuk mengira purata nombor dalam lajur atau sekumpulan sel, contohnya: =AVERAGE(A1:A10). 3. Fungsi COUNT, digunakan untuk mengira bilangan nombor atau teks dalam lajur atau sekumpulan sel, contohnya: =COUNT(A1:A10) 4. Fungsi IF, digunakan untuk membuat pertimbangan logik berdasarkan syarat yang ditentukan dan mengembalikan hasil yang sepadan.

Pengecualian Fungsi C++ Lanjutan: Pengendalian Ralat Tersuai Pengecualian Fungsi C++ Lanjutan: Pengendalian Ralat Tersuai May 01, 2024 pm 06:39 PM

Pengendalian pengecualian dalam C++ boleh dipertingkatkan melalui kelas pengecualian tersuai yang menyediakan mesej ralat khusus, maklumat kontekstual dan melaksanakan tindakan tersuai berdasarkan jenis ralat. Tentukan kelas pengecualian yang diwarisi daripada std::exception untuk memberikan maklumat ralat tertentu. Gunakan kata kunci lontaran untuk membuang pengecualian tersuai. Gunakan dynamic_cast dalam blok try-catch untuk menukar pengecualian yang ditangkap kepada jenis pengecualian tersuai. Dalam kes sebenar, fungsi open_file membuang pengecualian FileNotFoundException Menangkap dan mengendalikan pengecualian boleh memberikan mesej ralat yang lebih spesifik.

Panduan untuk menguji unit fungsi serentak Go Panduan untuk menguji unit fungsi serentak Go May 03, 2024 am 10:54 AM

Unit menguji fungsi serentak adalah penting kerana ini membantu memastikan kelakuan mereka yang betul dalam persekitaran serentak. Prinsip asas seperti pengecualian bersama, penyegerakan dan pengasingan mesti dipertimbangkan semasa menguji fungsi serentak. Fungsi serentak boleh diuji unit dengan mensimulasikan, menguji keadaan perlumbaan dan mengesahkan keputusan.

Perkara yang perlu diambil perhatian apabila fungsi Golang menerima parameter peta Perkara yang perlu diambil perhatian apabila fungsi Golang menerima parameter peta Jun 04, 2024 am 10:31 AM

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.

Bagaimana untuk menggunakan kelas atom dalam fungsi Java concurrency dan multi-threading? Bagaimana untuk menggunakan kelas atom dalam fungsi Java concurrency dan multi-threading? Apr 28, 2024 pm 04:12 PM

Kelas atom ialah kelas selamat benang di Java yang menyediakan operasi tanpa gangguan dan penting untuk memastikan integriti data dalam persekitaran serentak. Java menyediakan kelas atom berikut: AtomicIntegerAtomicLongAtomicReferenceAtomicBoolean Kelas ini menyediakan kaedah untuk mendapatkan, menetapkan dan membandingkan nilai untuk memastikan bahawa operasi adalah atom dan tidak akan diganggu oleh benang. Kelas atom berguna apabila bekerja dengan data kongsi dan mencegah rasuah data, seperti mengekalkan akses serentak ke kaunter kongsi.

See all articles