Go:内核线程、LWP、用户线程? 还是协程?

1.三种概念——内核线程、轻量级进程、用户线程:

https://blog.csdn.net/qq_32252957/article/details/82983969

内核线程

使用内核栈和和寄存器空间,但是调度成本高,等价于进程

内核线程就是内核的分身,一个分身可以处理一件特定事情。这在处理异步事件如异步IO时特别有用。内核线程的使用是廉价的,唯一使用的资源就是内核栈和上下文切换时保存寄存器的空间。支持多线程的内核叫做多线程内核。

轻量级进程(LWP)

共用父进程的资源,调度同普通进程

轻量级进程(LWP)是建立在内核之上并由内核支持的用户线程,它是内核线程的高度抽象,每一个轻量级进程都与一个特定的内核线程关联。内核线程只能由内核管理并像普通进程一样被调度。


用户线程:

与所属进程共享进程地址空间和系统资源,调度:由在用户空间实现的线程库,在所属进程内进行调度

用户线程是完全建立在用户空间的线程库,用户线程的创建、调度、同步和销毁全又库函数在用户空间完成,不需要内核的帮助。因此这种线程是极其低消耗和高效的。

2.用户多线程的实现方式:

https://blog.csdn.net/qq_32252957/article/details/82983969

a.LWP作为多线程方案

缺点:LWP数量存在限制,LWP利用率较低

è¿éåå¾çæè¿°

b.纯用户空间多线程方案

缺点:如果某个用户线被阻塞,导致进程同样被阻塞

è¿éåå¾çæè¿°

c.混合版多线程方案

用户线程底层对应多LWP,减少线程切换代价的同时,提升并行能力

è¿éåå¾çæè¿°

3.linux的线程实现:

https://blog.csdn.net/tianyue168/article/details/7403693

Linux 线程采用LWP实现,一个线程对应一个LWP,一对一关系

4.核心线程和用户线程的区别:

https://blog.csdn.net/gatieme/article/details/51892437

5.协程:

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 调度器

http://skoo.me/go/2013/11/29/golang-schedule?utm_campaign=studygolang.com&utm_medium=studygolang.com&utm_source=studygolang.com

调度原理图:

M:核心线程

P:执行器

G:goroutine任务

goroutine任务会首先放到global queue中,然后再下放到具体的goroutine执行器队列中

Go:内核线程、LWP、用户线程? 还是协程?_第1张图片

你可能感兴趣的:(Golang并发)