Go 语言中 channel 使用总结
2014-03-26 20:41
531 查看
Go 语言中的 channel 是实现 goroutine 间无锁通信的关键机制,他使得写多线程并发程序变得简单、灵活、触手可得。下面就个人理解对 channel 使用过程中应该注意的地方进行一个简要的总结。
channel 分类: 不带缓存 channel, 带缓存 channel
(1)不带缓存 channel
语法:
(a)创建channel
make(chan type)
e.g. ch := make(chan int)
(b)通信方式(由于chan操作类似于Queue,为便于理解这里用EnQueue,DeQueue来描述通信操作)
EnQueue: ch <- typevar DeQueue: var := <- ch
e.g. ch <- 1 v := <-ch
关键:
调用channel EnQueue 操作之后被阻塞住(不管channel是否为空),直到写的数据被读取掉。调用channel DeQueue 操作时,如果channel中有数据则被读出,如果为空则阻塞住,直到有人往里面EnQueue数据。
(2)带缓存 channel
语法:
(a)创建channel
make(chan type, size)
e.g. ch := make(chan int, 9)
(b)通信方式
同不带缓存channel
关键:
当channel中元素小于等于channel size时,调用channel EnQueue 操作后数据被放入到缓存中(非阻塞);当channel满以后,如果再调用EnQueue操作就会被阻塞住直到有元素被DeQueue出来。调用channel DeQueue 操作时,如果channel 为空则阻塞住直到有人往里面EnQueue数据,否则直接DeQueue出元素。
Note: 需要特别注意的是两者对于range操作的区别:无缓存channel是EnQueue一个数据被range读一个;而带缓存channel是EnQueue满之后被range整个一起拿出来用(这个机制对于用户是透明的,用户看到的还是一个一个拿出来),或者timeout时间到之后即使channel没有满也会被range拿出来。另外,channel 关闭之后,循环读channel操作(e.g. for v:=range channel) 读完channel中剩余数据会自动跳出循环。
channel 分类: 不带缓存 channel, 带缓存 channel
(1)不带缓存 channel
语法:
(a)创建channel
make(chan type)
e.g. ch := make(chan int)
(b)通信方式(由于chan操作类似于Queue,为便于理解这里用EnQueue,DeQueue来描述通信操作)
EnQueue: ch <- typevar DeQueue: var := <- ch
e.g. ch <- 1 v := <-ch
关键:
调用channel EnQueue 操作之后被阻塞住(不管channel是否为空),直到写的数据被读取掉。调用channel DeQueue 操作时,如果channel中有数据则被读出,如果为空则阻塞住,直到有人往里面EnQueue数据。
(2)带缓存 channel
语法:
(a)创建channel
make(chan type, size)
e.g. ch := make(chan int, 9)
(b)通信方式
同不带缓存channel
关键:
当channel中元素小于等于channel size时,调用channel EnQueue 操作后数据被放入到缓存中(非阻塞);当channel满以后,如果再调用EnQueue操作就会被阻塞住直到有元素被DeQueue出来。调用channel DeQueue 操作时,如果channel 为空则阻塞住直到有人往里面EnQueue数据,否则直接DeQueue出元素。
Note: 需要特别注意的是两者对于range操作的区别:无缓存channel是EnQueue一个数据被range读一个;而带缓存channel是EnQueue满之后被range整个一起拿出来用(这个机制对于用户是透明的,用户看到的还是一个一个拿出来),或者timeout时间到之后即使channel没有满也会被range拿出来。另外,channel 关闭之后,循环读channel操作(e.g. for v:=range channel) 读完channel中剩余数据会自动跳出循环。
相关文章推荐
- go语言通道channel使用总结
- TODO:Go语言goroutine和channel使用
- 总结Go语言中defer的使用和注意要点
- TODO:Go语言goroutine和channel使用
- Go语言中使用 buffered channel 实现线程安全的 pool
- Go语言中的管道(Channel)总结
- Go语言ssh简单的使用
- 使用python语言编写脚本控制freeswitch总结
- Go语言开发环境配置教程及使用
- go语言defer使用
- Go 语言基本类型总结
- go语言使用pipe读取子进程标准输出的方法
- Go语言实现http共享(总结)
- Go语言中 Channel 详解
- Go语言开发-关于LiteIDE使用第三库时没有自动提示的解决方法
- 使用Sublime text 3打造一个小巧但强大的Go语言开发IDE
- 25.笔记go语言——PostgrelSQL数据库使用
- go语言web框架 beego初步使用笔记
- Go语言基础知识总结(语法、变量、数值类型、表达式、控制结构等)