Golang并发、协程

栏目: Go · 发布时间: 7年前

并行(parallel):指在同一时刻,有多条指令在多个处理器上同时执行。

并发(concurrency):指在同一时刻只能有一条指令执行,但多个进程指令被快速的轮换执行,使得在宏观上具有多个进程同时执行的效果,但在微观上并不是同时执行的,只是把时间分成若干段,使多个进程快速交替的执行。

goroutine

goroutine是比线程更小的工作单元,go语言内部实现了goroutine之间的内存共享,它比thread更易用、更高效、更轻便。

创建goroutine

只需要在函数调用语句前添加"go"关键字,就可以创建并发执行单元。当一个程序启动时,其主函数即在一个单独的goroutine中运行,称为main goroutine。当主协程结束的时候,子协程也会自动结束。

Gosched

runtime包的方法,让出时间片,让其它协程先执行

Goexit

runtime 包的方法,终止所在协程

GOMAXPROCS

runtime包的方法,获取最大核心数,指定使用核心数

channel

channel是内置的数据结构,用于读取发送数据,无数据时,读取数据会阻塞,设置了最大写入数据时,写满capacity个元素时,写入阻塞。

channel创建

make(chan Type)

make(chan Type, capacity)

channel读写

ch <- 666

<- ch

无缓冲的channel

make(chan Type)

make(chan Type,0)

有缓冲的channel

是一种在被接受前能存储一个或多个值得channel

make(chan Type,3)

单向channel

var send chan<- int

var receiver <-chan int


以上所述就是小编给大家介绍的《Golang并发、协程》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

数字乌托邦

数字乌托邦

尼古拉斯•卡尔 / 姜忠伟 / 中信前沿出版社 / 2018-5 / 69.00

当下,技术与我们的关系变得越来越紧密不可分割,特别是智能手机等设备的出现,带给整个人类社会一场彻底的变革。的确,智能手机上的各种应用程序让我们的工作生活无比便利:社交媒体让我们能够和他人实时保持联络并传输信息,不再受时间、地点的限制;搜索引擎通过精准的算法将我们所需要的信息整合推送至屏幕上,让我们毫不费力就看到自己想要的;地图软件为我们的出行提供了更多路线选择,甚至可以使用语音导航,帮助我们顺利到......一起来看看 《数字乌托邦》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试