首页后端开发其他后端知识golang是多线程模式吗,如何理解

golang是多线程模式吗,如何理解

时间2024-03-27 04:48:03发布访客分类其他后端知识浏览808
导读:这篇文章分享给大家的内容是关于golang是多线程模式吗,如何理解,本文介绍得很详细,内容很有参考价值,希望可以帮到有需要的小伙伴,接下来就让小编带领大家一起了解看看吧。 golang是多线程模式的,golang的线程模型是...
这篇文章分享给大家的内容是关于golang是多线程模式吗,如何理解,本文介绍得很详细,内容很有参考价值,希望可以帮到有需要的小伙伴,接下来就让小编带领大家一起了解看看吧。

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

golang是多线程模式。

由于gmp中的p与m是将p绑定与m内核线程上,而后p的最大数量有GOPROCESS确定,而M内核线程的数量会由go去限制为10K个,但是由于内核原因做不到这么多,所以这个限制就当做没有吧。拿个图明确一下

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数相同的活跃线程数。


以上就是关于golang是多线程模式吗,如何理解的介绍啦,需要的朋友可以参考上述内容,希望对大家有帮助,欢迎关注网络,小编将为大家输出更多高质量的实用文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

golang多线程

若转载请注明出处: golang是多线程模式吗,如何理解
本文地址: https://pptw.com/jishu/653989.html
Golang是怎么进行处理excel的,方法是什么? go语言grpc环境如何搭建,详细操作是怎样

游客 回复需填写必要信息