Frequently Asked Questions :Go为什么用协程替代线程?

Gorountine(协程)让并发编程变成简单。这个设计能让程序多通道地执行在一系列的线程上,当一个协程阻塞了,例如执行了一段系统阻塞命令。“运行时”系统runtime会自动地将其它的协程转移到,同处于一个系统态的线程的其他协程转移到另外一个可运行的线程中,这样这些协程就不会被阻塞。程序员是看不到这些细节实现的,这其实很关键。我们执行一个协程代价十分低。它的花销不超过一个堆栈的空间。

为了让堆栈更小,Go的运行在一个可扩容的(但有上限)的堆栈。一个新造的协程初始容量是几个kb,在一个堆栈中能够容纳的协程数量几乎够用了。如果不够用的时候,go的运行时会自动扩容堆栈,来提高容纳协程数量。每一个函数调用只花费3个低消耗的指令。

在同一个内存地址上创建成百上千个协程十分便捷,而如果使用线程,相同数量情况下,系统资源会很快被消耗干净。

multiplex 多路的、多样的
overhead n 花销
mint adj 完美的、新造的
modest adj 适度的,谦虚的
instruction n 指令
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值