GO语言学习之并发

并发编程

并发包含以下几种主流的实现模型

多进程,多进程是在操作系统层面进行并发的基本模式

多线程,多线程在大部分操作系统上都属于系统层面的并发模式

基于回调的非阻塞/异步IO,使用多线程模式会很快耗尽服务器的内存和CPU资源

协程,协程本质上是一种用户态线程,不需要操作系统来进行抢占式调度,且在真正的实现中寄存于线程中

Channel

声明

var channamechan elementtype

例 var  ch chan int

   var m map[string] chan bool  map中的元素是bool类型的chan

定义

Ch :=make(chanint)

将一个数据写入到channel

Ch<-value

从channel读取数据

Value :=<-ch

单向channel声明:

Var ch1chan int  ch1是一个正常的channel不是单向的

Var ch2chan <-float64 ch2是单向channel,只用于写float64的值

Var ch3<-chan int ch3是单向channel,只用于读int类型、

关闭channel: close(ch)

如何判断channel被关闭

X,ok:=<-ch 第二个值为false,则关闭

例子:http://blog.youkuaiyun.com/shangguan_1234/article/details/79584856
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值