可以通过 channel 实现共享内存的 goroutine:创建一个 channel 以指定元素类型。启动一个 goroutine 向 channel 写入数据。在主 goroutine 中使用 range 循环从 channel 读取数据。通过关闭 channel 表示完成写入。
如何在 Go 中创建一个共享内存的 Goroutine?
在 Go 中,共享内存是通过 channel 实现的。channel 本质上是一个先进先出的(FIFO)队列,用于在 Goroutine 之间发送和接收值。
实战案例
创建一个共享内存的 Goroutine 非常简单。以下是示例代码:
package main
import (
"fmt"
"sync"
)
func main() {
// 创建一个 channel
ch := make(chan int)
// 创建 Goroutine 并启动,它将向 channel 写入数据
var wg sync.WaitGroup
wg.Add(1)
go func() {
defer wg.Done()
for i := 0; i < 10; i++ {
ch <- i
}
// 关闭 channel 表示完成
close(ch)
}()
// 从 channel 中读取数据
for v := range ch {
fmt.Println(v)
}
wg.Wait()
}
解释
- 创建一个 channel 时,需要指定其元素类型(在本例中为 int)。
- go 语句启动一个新的 Goroutine,并将一个函数作为参数传递。
- 在 Goroutine 中,我们使用一个 for 循环向 channel 写入数据。
- 当 Goroutine 完成时,可以使用 close(ch) 关闭 channel。
- 在主 Goroutine 中,我们使用一个 range 循环从 channel 中读取数据。直到 channel 被关闭,range 循环才会退出。
通过使用 channel 进行共享内存,我们可以安全地在各个 Goroutine 之间传递数据。