php中文网

Golang 函数中 goroutine 之间如何通信?

php中文网

goroutine 之间通信的方法包括:通道:用于安全传输数据值,允许一个 goroutine 发送数据,另一个 goroutine 接收数据。原子变量:可并发读写的变量,无需锁,适合维护共享状态。等待组:用于管理一组并行 goroutine,允许等待所有 goroutine 完成后再继续执行。

Go 函数中 goroutine 之间的通信

Go 中的 goroutine 是一种轻量级线程,允许您并发执行代码。goroutine 之间需要通信以交换数据或协调任务。Go 提供了多种机制来实现 goroutine 之间的通信。

通道

立即学习“go语言免费学习笔记(深入)”;

通道是一种在 goroutine 之间安全传输数据的值类型。它们允许一个 goroutine 将数据发送到通道,而另一个 goroutine 可以从通道接收数据。

package main

import (
    "fmt"
    "time"
)

func main() {
    // 创建一个通道
    ch := make(chan int)

    // 启动一个 goroutine 发送数据到通道
    go func() {
        ch <- 42 // 发送数据到通道
    }()

    // 启动一个 goroutine 从通道接收数据
    go func() {
        value := <-ch // 从通道接收数据
        fmt.Println(value)
    }()

    time.Sleep(500 * time.Millisecond) // 等待 goroutine 运行
}

原子变量

原子变量是可以并发读写而无需锁的变量。它们对于维护共享状态非常有用。

package main

import (
    "fmt"
    "runtime"
    "sync/atomic"
)

func main() {
    // 创建一个原子变量
    var counter int64

    // 启动多个 goroutine 并发增加计数器
    for i := 0; i < runtime.NumCPU(); i++ {
        go func() {
            for j := 0; j < 1000; j++ {
                atomic.AddInt64(&counter, 1) // 并发增加计数器
            }
        }()
    }

    time.Sleep(500 * time.Millisecond) // 等待 goroutine 运行

    fmt.Println(counter) // 打印最终计数
}

等待组

等待组是一个用于管理一组并行执行的 goroutine 的机制。它允许您等待所有 goroutine 完成后再继续执行。

package main

import (
    "fmt"
    "sync"
)

func main() {
    // 创建一个等待组
    var wg sync.WaitGroup

    // 启动多个 goroutine
    for i := 0; i < 10; i++ {
        wg.Add(1) // 增加等待组计数器

        go func(i int) {
            defer wg.Done() // 减少等待组计数器
            fmt.Println(i)
        }(i)
    }

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

    fmt.Println("所有 goroutine 已完成")
}

以上就是Golang 函数中 goroutine 之间如何通信?的详细内容,更多请关注php中文网其它相关文章!