社区微信群开通啦,扫一扫抢先加入社区官方微信群
社区微信群
https://blog.csdn.net/qq_32252957/article/details/82983969
内核线程:
使用内核栈和和寄存器空间,但是调度成本高,等价于进程
内核线程就是内核的分身,一个分身可以处理一件特定事情。这在处理异步事件如异步IO时特别有用。内核线程的使用是廉价的,唯一使用的资源就是内核栈和上下文切换时保存寄存器的空间。支持多线程的内核叫做多线程内核。
轻量级进程(LWP):
共用父进程的资源,调度同普通进程
轻量级进程(LWP)是建立在内核之上并由内核支持的用户线程,它是内核线程的高度抽象,每一个轻量级进程都与一个特定的内核线程关联。内核线程只能由内核管理并像普通进程一样被调度。
用户线程:
与所属进程共享进程地址空间和系统资源,调度:由在用户空间实现的线程库,在所属进程内进行调度
用户线程是完全建立在用户空间的线程库,用户线程的创建、调度、同步和销毁全又库函数在用户空间完成,不需要内核的帮助。因此这种线程是极其低消耗和高效的。
https://blog.csdn.net/qq_32252957/article/details/82983969
a.LWP作为多线程方案
缺点:LWP数量存在限制,LWP利用率较低
b.纯用户空间多线程方案
缺点:如果某个用户线被阻塞,导致进程同样被阻塞
c.混合版多线程方案
用户线程底层对应多LWP,减少线程切换代价的同时,提升并行能力
https://blog.csdn.net/tianyue168/article/details/7403693
Linux 线程采用LWP实现,一个线程对应一个LWP,一对一关系
https://blog.csdn.net/gatieme/article/details/51892437
a.协程相比于线程的优势
资源占用小,堆栈大小只有若干 kb,可以进行增减,并将数据存储于堆空间中
OS内核线程复用程度更高,1个线程可以对应N个goroutine
协程使用信道(Channel)来进行通信。
简单来说:调度(M:N)、单个协程资源占用
b.Go的协程执行原理
白话文讲解:https://blog.51cto.com/1427133/2160211
底层:http://www.sizeofvoid.net/goroutine-under-the-hood/
c.Go 调度器
调度原理图:
M:核心线程
P:执行器
G:goroutine任务
goroutine任务会首先放到global queue中,然后再下放到具体的goroutine执行器队列中
如果觉得我的文章对您有用,请随意打赏。你的支持将鼓励我继续创作!