新的一年开始了,不管今天以前发生了什么,向前看,就够了。

  说到channel,就一定要说一说线程了。任何实际项目,无论大小,并发是必然存在的。并发的存在,就涉及到线程通信。在当下的开发语言中,线程通讯主要有两种,共享内存与消息传递。共享内存一定都很熟悉,通过共同操作同一对象,实现线程间通讯。消息传递即通过类似聊天的方式。golang对并发的处理采用了协程的技术。golang的goroutine就是协程的实现。协程的概念很早就有,简单的理解为轻量级线程,goroutine就是为了解决并发任务间的通信而设计的。golang解决通信的理念是:不要通过共享内存来通信,而应该通过通信来共享内存。golang解决方案是消息传递机制,消息的传递就是通过channel来实现的。

  channel的使用很简单,这里就不在粘别人的东西了。现在谈一谈对channe阻塞l的理解。  

  发送者角度:对于同一个通道,发送操作(协程或者函数中的),在接收者准备好之前是阻塞的。如果chan中的数据无人接收,就无法再给通道传入其他数据。因为新的输入无法在通道非空的情况下传入。所以发送操作会等待 chan 再次变为可用状态:就是通道值被接收时(可以传入变量)。

  接收者角度:对于同一个通道,接收操作是阻塞的(协程或函数中的),直到发送者可用:如果通道中没有数据,接收者就阻塞了。

  通过一个简单的例子来说明:

  

 package main

 import (
"fmt"
) func f1(in chan int) {
fmt.Println(<-in)
} func main() {
out := make(chan int)
out <-
go f1(out)
}

  运行结果:fatal error: all goroutines are asleep - deadlock!

  这是由于第13行之前不存在对out的接收,所以,对于out <- 2来说,永远是阻塞的,即一直会等下去。

  将13,14行互换

 package main

 import (
"fmt"
) func f1(in chan int) {
fmt.Println(<-in)
} func main() {
out := make(chan int)
go f1(out)
out <-
}

  运行结果:2

  14行前存在对管道的读操作,所以out <- 是合法的。就像前文说的,发送操作在接收者准备好之前是阻塞的。

最新文章

  1. 使用Azure REST API创建虚拟机
  2. Linux机器24项安全合规设置
  3. Fireeye火眼公司发布报告,评论中国网络间谍活动
  4. python thread 多线程
  5. Xcode 8 新特性
  6. WebApi中直接返回json字符串的方法
  7. BusyBox Init
  8. 让Grub 2来拯救你的 bootloader
  9. 在线浏览pdf文件,pdfobject的简单使用
  10. 电脑远程控制手机2—webkey
  11. linux查看CPU和内存信息
  12. 最长公共子序列poj1458
  13. SpringMVC拦截器 - 设置不拦截html,js等静态文件
  14. day4 liaoxuefeng---高级特性
  15. XXE (XML External Entity Injection) 外部实体注入漏洞案例分析
  16. self.location.href
  17. WEB服务器与应用服务器的区别
  18. Linux shell 将字符串分割成数组
  19. Core WebAPI 入门
  20. Mac环境搭建以太坊私有链

热门文章

  1. [TypeScript] Collect Related Strings in a String Enum in TypeScript
  2. [Sqlite3] Sqlite Introduction
  3. C++学习之构造函数中的异常处理
  4. firewalld filter
  5. JSON入门指南
  6. SpringMVC上传文件后返回文件服务器地址路径
  7. BZOJ 1037: [ZJOI2008]生日聚会Party 四维DP
  8. 在js中取选中的radio值
  9. SpringMVC 运行过程
  10. Could not find modernizr-2.6.2 in any of the sources