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中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号