iis服务器助手广告
返回顶部
首页 > 资讯 > 精选 >如何在 Golang 并行处理中同步随机数生成?
  • 310
分享到

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

golangrand并发访问 2024-05-13 22:05:35 310人浏览 八月长安
摘要

在 Go 并发编程中同步随机数生成:使用互斥锁 (sync.mutex) 控制对 rand.rand 随机数生成器的访问。每个 goroutine 在生成随机数前获取互斥锁,并在生成后释

Go 并发编程中同步随机数生成:使用互斥 (sync.mutex) 控制对 rand.rand 随机数生成器的访问。每个 goroutine 在生成随机数前获取互斥锁,并在生成后释放互斥锁。这确保了同一时间只有一个 goroutine 可以访问随机数生成器,消除了数据争用。

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

在 Go 并发编程中,有时需要跨多个 goroutine 生成随机数。如果不注意同步,这可能会导致竞争条件和不可预测的行为。

并行随机数生成

Go 提供了一个 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 随机数生成器的访问。每个 goroutine 在生成随机数之前都会获取互斥锁,并在生成后释放互斥锁。这确保了同一时间只有一个 goroutine可以访问随机数生成器,从而消除了数据争用。

通过这种方式,可以在并行处理中安全可靠地生成随机数。

以上就是如何在 Golang 并行处理中同步随机数生成?的详细内容,更多请关注编程网其它相关文章!

--结束END--

本文标题: 如何在 Golang 并行处理中同步随机数生成?

本文链接: https://www.lsjlt.com/news/616423.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作