channel有点类似于管道,它在goroutine同步与通信中,有着起承转合的作用,同时也是Golang实现CSP模型的关键。

golang 中大部分类型都是值类型(只有 slice / channel / map 是引用类型),读/写类型是值类型的 channel 时,如果元素 size 比较大时,应该使用指针代替,避免频繁的内存拷贝开销。

golang判断channel是否已经close的方法:

读channel的时候判断其是否已经关闭

_,ok := <- jobs

此时如果 channel 关闭,ok 值为 false

写入channel的时候判断其是否已经关闭

1、_,ok := <- jobs

此时如果 channel 关闭,ok 值为 false,如果 channel 没有关闭,则会漏掉一个 jobs

2、使用 select 方式

再创建一个 channel,叫做 timeout,如果超时往这个 channel 发送 true,在生产者发送数据给 jobs 的 channel,用 select 监听 timeout,如果超时则关闭 jobs 的 channel.

go func() { time.Sleep(time.Second * 3) timeout <- true }()
go func() { for i := 0; ; i++ { select {     case <-timeout:         close(jobs)         return      default:         jobs <- i         fmt.Println("produce:", i)         }     } }()

更多golang知识请关注golang教程栏目。

更多相关文章

  1. golang怎么把字符串转成Int类型
  2. golang判断错误类型的方法
  3. 详解 Go 中的不可变类型
  4. 总结 Go 的数据类型
  5. 详解Golang中函数作为值与类型
  6. 解决golang中vendor引起的相同类型,却提示类型不一样问题
  7. go是强类型语言么
  8. go语言 类型转换表示什么
  9. 疯狂XML学习笔记(8)---------schema 的简单类型

随机推荐

  1. Linux 常用命令使用英文全称
  2. 【Azure】两台Linux虚拟机挂载共享文件
  3. Linux QT5.2下编译MySQL5.6.7驱动
  4. Linux使用wget下载整站
  5. Linux下SVN服务器安装配置及客户端安装说
  6. Ubuntu(16.04.2)学习笔记(一)如何解决dpkg:
  7. 使用Bash编写Linux Shell脚本-9. 参数和
  8. REDIS从LINUX文件写入批量数据
  9. Android usb client mass-storage 多存储
  10. linux 命令 grep 不使用 正则表达式