golang是单进程的吗?


本文摘自php中文网,作者coldplay.xixi,侵删。

golang不是单进程的,而是多线程;golang的线程模型是M P G模型,整体上Go程与内核线程是多对多对应的,因此首先来讲就一定是多线程的。

golang不是单进程的,而是多线程。

Golang有些所谓的M比N模型,M个线程下可以创建N个go routine,一般而言N远大于M,本质上属于多线程模型,但是协程的调度由Go的runtime决定,强调开发者应该使用channel进行协程之间的同步。

至于线程,由于语言层面上不开放,你可以理解为其实是多协程模型,一个线程上可以创建若干个go routine,一般而言会创建与CPU核心数相同的线程数,当然实际上还是由runtime决定。

对于goroutine的调度,这个其实是一直在发展变化的,我只说一下GMP模型,goroutine在M个线程上运行,每次执行任务都会去查当前P(处理器)上的可执行队列,队列里面就是可以执行的goroutine,一旦当前P上没有可供执行的它就会去窃取另一个P的可执行队列中的goroutine。

而goroutine的创建理论上来说只受内存限制,一般而言最大也就2KB,对于一个线程2MB空间大小理论上来说可以轻易上1000个,当然这只是理想情况下,所以OS线程数不会随着goroutine创建个数增加而增加。线程调度是对于go来说会比较耗费性能,频繁切换调度只会在goroutine之间存在,线程只会保持与cpu数相同的活跃线程数。

相关学习推荐:Go语言教程

以上就是golang是单进程的吗?的详细内容,更多文章请关注木庄网络博客!!

相关阅读 >>

分享5种文件变更时自动重载go程序的方法

手撸golang 行为型设计模式 责任链模式

基于golang的手机号格式验证和邮箱格式验证

go - 变量声明

golang 泛型

手撸golang 行为型设计模式 模板方法模式

golang 可以多继承吗

golang不适合开发web吗

go语言学习(四):数组和切片

go - 实现项目内链路追踪(二)

更多相关阅读请进入《golang》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...