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

前端之家收集整理的这篇文章主要介绍了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, 欢迎各位使用,如有错误,请各位及时反馈,谢谢!

猜你在找的Go相关文章