Golang中的管道channel在几个典型语言中的实现

用golang有一段时间了,Golang中的管道确实是一个神器,我们用生产者-消费者来描述其基本用法为:

func P(queue chan<- int){
    for i:= 0; i < 1000; i++{
        queue <- i
    }
}

func C(queue <-chan int){
    v := <- queue
}

func main(){
     queue := make(chan int,10)  // 这里的10表示管道的容量,根据应用的需求进行设置
     go P(queue)
     go C(queue)
}


上例中的管道的用途是:生产者向管道中添加数据,当管道被填满(上例中是10个数据)时,生产者阻塞(等待消费者消费);当管道中有数据时,消费者从管道中获取数据,否则,阻塞(等待生产者向其中添加数据)。

显然,golang的基于消息通讯的模式极大地简化了上述需求,在其它语言中实现起来需要锁和条件变量等,比较麻烦。

因为这个场景几乎在所有的项目中都会用到,最近特地实现了C++,java,C#三个版本,github地址为:https://github.com/ChenJohnson/Channel, 欢迎各位使用,如有错误,请各位及时反馈,谢谢!

相关文章

程序目录结构 简单实现,用户登录后返回一个jwt的token,下次请求带上token请求用户信息接口并返回信息...
本篇博客的主要内容是用go写一个简单的Proof-of-Work共识机制,不涉及到网络通信环节,只是一个本地的简...
简介 默克尔树(MerkleTree)是一种典型的二叉树结构,其主要特点为: 最下面的叶节点包含存储数据或其...
接下来学习并发编程, 并发编程是go语言最有特色的地方, go对并发编程是原生支持. goroutine是go中最近本...
先普及一下, 什么是广度优先搜索 广度优先搜索类似于树的层次遍历。从图中的某一顶点出发,遍历每一个顶...
第一天: 接口的定义和实现 第二天: 一. go语言是面向接口编程. 在学习继承的时候说过, go语言只有封装,...