1 线程
CPU调度的最小单元。程序执行的基本单位。
2 线程模型
图中三个层次,OS放在最外层,我是这样理解的:CPU的资源在操作系统级别调度,所有的程序均运行在操作系统中,因此把OS放在最外层。
2.1 内核线程模型
系统的线程。系统级别可以操作的线程。
重量级线程。切换线程损耗的系统性能较多。但可以利用多核。
多线程情况下,1个线程对应一个核。线程:核=1:1。
可以充分利用多核处理器,提高并行和并发能力。
创建的线程数量会直接影响系统性能。
Java即内核线程模型。
2.2 用户线程模型
进程的线程。应用程序级别可以操作的线程。
线程更加轻量,无需通过内核操作。
系统无法直接操作用户线程,只能通过干预进程间接干预线程。
比如杀死某个进程,该进程中的所有线程都会停止。
一个核对应多个线程。线程:核=n:1。
多线程情况下,共用单核处理器,无法发挥多核处理器性能。
Python的gevent是用户线程模型,即协程模型。