Rumah >pembangunan bahagian belakang >Golang >Bagaimana untuk menyegerakkan penjanaan nombor rawak dalam pemprosesan selari Golang?

Bagaimana untuk menyegerakkan penjanaan nombor rawak dalam pemprosesan selari Golang?

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBasal
2024-06-03 14:53:56409semak imbas

Penjanaan nombor rawak disegerakkan dalam pengaturcaraan serentak Go: Gunakan mutex (sync.Mutex) untuk mengawal akses kepada penjana nombor rawak rand.Rand. Setiap goroutine memperoleh muteks sebelum menjana nombor rawak dan melepaskan muteks selepas menjananya. Ini memastikan bahawa hanya satu goroutine boleh mengakses penjana nombor rawak pada satu masa, menghapuskan perlumbaan data.

如何在 Golang 并行处理中同步随机数生成?

Bagaimana untuk menyegerakkan penjanaan nombor rawak dalam pemprosesan selari Golang?

Dalam pengaturcaraan serentak Go, kadangkala perlu menjana nombor rawak merentas berbilang goroutin. Jika penyegerakan tidak dijaga, ini boleh menyebabkan keadaan perlumbaan dan tingkah laku yang tidak dapat diramalkan.

Penjanaan nombor rawak selari

Go menyediakan pakej matematik/rand untuk menjana nombor rawak pseudo. Secara lalai, ia beroperasi dengan cara yang tidak selamat. Ini bermakna jika contoh rand.Rand yang sama diakses secara serentak, perlumbaan data dan keputusan tidak tentu akan berlaku. math/rand 包来生成伪随机数。默认情况下,它以非并发安全的方式操作。这意味着如果并发访问同一个 rand.Rand 实例,则会出现数据争用和不确定的结果。

使用互斥锁进行同步

为了在并行处理中同步随机数生成,可以使用互斥锁 (sync.Mutex)。互斥锁允许一次只有一个 goroutine 访问临界区(在这种情况下,rand.Rand 实例)。

以下代码演示如何使用互斥锁同步随机数生成:

package main

import (
    "math/rand"
    "sync"
)

var (
    // 全局互斥锁
    randomLock sync.Mutex
    
    // 全局随机数生成器
    randomGen *rand.Rand
)

func init() {
    // 在程序启动时初始化随机数生成器
    // 并设置随机种子
    randomGen = rand.New(rand.NewSource(time.Now().UnixNano()))
}

func main() {
    // 创建一个等待组来跟踪 goroutine
    var wg sync.WaitGroup
    
    // 启动 10 个 goroutine 生成 10 个随机数
    for i := 0; i < 10; i++ {
        wg.Add(1)
        go func(i int) {
            // 使用互斥锁保护随机数生成
            randomLock.Lock()
            value := randomGen.Intn(100)
            randomLock.Unlock()
            
            // 打印生成的随机数
            fmt.Printf("Goroutine %d: %d\n", i, value)
            wg.Done()
        }(i)
    }

    // 等待所有 goroutine 完成
    wg.Wait()
}

在这种方法中,使用了一个全局 randomLock 互斥锁来保护对 randomGen

Penyegerakan menggunakan mutexes

Untuk menyegerakkan penjanaan nombor rawak dalam pemprosesan selari, anda boleh menggunakan kunci mutex (sync.Mutex). Mutex membenarkan hanya satu goroutine mengakses bahagian kritikal pada satu masa (dalam kes ini, contoh rand.Rand). 🎜🎜Kod berikut menunjukkan cara menggunakan mutex untuk menyegerakkan penjanaan nombor rawak: 🎜rrreee🎜Dalam pendekatan ini, mutex randomLock global digunakan untuk melindungi akses kepada randomGen Access kepada penjana nombor rawak. Setiap goroutine memperoleh muteks sebelum menjana nombor rawak dan melepaskan muteks selepas menjananya. Ini memastikan bahawa hanya satu goroutine mempunyai akses kepada penjana nombor rawak pada satu masa, menghapuskan perlumbaan data. 🎜🎜Dengan cara ini, nombor rawak boleh dijana dengan selamat dan boleh dipercayai dalam pemprosesan selari. 🎜

Atas ialah kandungan terperinci Bagaimana untuk menyegerakkan penjanaan nombor rawak dalam pemprosesan selari Golang?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
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