分享
分析该缓冲通道wrote和read的数字的顺序
SmallForest · · 1003 次点击 · · 开始浏览这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。
分析该缓冲通道wrote和read的数字的顺序
package main
import (
"fmt"
"time"
)
func write(ch chan int) {
for i := 0; i < 5; i++ {
ch <- i
fmt.Println("successfully wrote", i, "to ch")
}
close(ch)
}
func main() {
ch := make(chan int, 2)
go write(ch)
time.Sleep(2 * time.Second)
for v := range ch {
fmt.Println("read value", v, "from ch")
time.Sleep(2 * time.Second)
}
}
在main中声明的ch的缓冲容量为2,根据缓冲通道的特点,当通道写满的时候写入方法write就会进入阻塞,range方法会读取通道ch中的值,由于存在2s的sleep,最终结果为
wrote 0 1 2 3 4
read 0 1 2 3 4
tips:不同的sleep时长会有不同的返回顺序
有疑问加站长微信联系(非本文作者)
入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889
关注微信1003 次点击
添加一条新回复
(您需要 后才能回复 没有账号 ?)
- 请尽量让自己的回复能够对别人有帮助
- 支持 Markdown 格式, **粗体**、~~删除线~~、
`单行代码` - 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
- 图片支持拖拽、截图粘贴等方式上传
收入到我管理的专栏 新建专栏
分析该缓冲通道wrote和read的数字的顺序
package main
import (
"fmt"
"time"
)
func write(ch chan int) {
for i := 0; i < 5; i++ {
ch <- i
fmt.Println("successfully wrote", i, "to ch")
}
close(ch)
}
func main() {
ch := make(chan int, 2)
go write(ch)
time.Sleep(2 * time.Second)
for v := range ch {
fmt.Println("read value", v, "from ch")
time.Sleep(2 * time.Second)
}
}
在main中声明的ch的缓冲容量为2,根据缓冲通道的特点,当通道写满的时候写入方法write就会进入阻塞,range方法会读取通道ch中的值,由于存在2s的sleep,最终结果为
wrote 0 1 2 3 4
read 0 1 2 3 4
tips:不同的sleep时长会有不同的返回顺序