Go - Channel

Go - Channel 首页 / Golang入门教程 / Go - Channel

通道充当管道,我们通过管道将键入的值从一个Goroutine发送到另一个Goroutine。由于在任何给定时间只有一个Goroutine可以访问数据项,因此可以保证同步。数据的所有权在不同的Goroutine之间传递。因此,通过设计,它避免了共享内存的陷阱,并防止了竞争情况。

Go通道示例

package main
import "fmt"
import "time"
func worker(done chan bool) {
   fmt.Print("working...")
   time.Sleep(time.Second)
   fmt.Println("done")
   done <- true
}
func main() {
   done := make(chan bool, 1)
   go worker(done)
   <-done
}

输出:

无涯教程网

working...done

祝学习愉快!(内容编辑有误?请选中要编辑内容 -> 右键 -> 修改 -> 提交!)

技术教程推荐

人工智能基础课 -〔王天一〕

MySQL实战45讲 -〔林晓斌〕

iOS开发高手课 -〔戴铭〕

后端存储实战课 -〔李玥〕

容量保障核心技术与实战 -〔吴骏龙〕

如何读懂一首诗 -〔王天博〕

程序员的个人财富课 -〔王喆〕

快手 · 移动端音视频开发实战 -〔展晓凯〕

计算机基础实战课 -〔彭东〕

好记忆不如烂笔头。留下您的足迹吧 :)