前引
博主最近在看哈工大李治军老师的操作系统课,为加强学习效果,所以把对OS暂时的理解记录在博客中。
线程分为用户级线程与内核级线程,前者是在用户态上运行的线程,不涉及操作系统内核的调度;后者是在内核态上运行线程,涉及操作系统内核的调度。 总体上,后者优于前者
一.用户级线程
1.1 是什么
一个进程A的指令序列被分成n个,成为进程A的n个线程。
这n个线程共享一个操作系统内核中的进程核心。
(图2操作系统调度器中的内核线程,就是内核进程,因为该内核进程只含有一个线程,即它本身)
所以在这n个线程之间的切换,不会涉及操作系统内核。
1.2 存在的问题
当其中一个线程需要使用计算机硬件而进入操作系统内核,因为要等待计算机硬件的使用权,该线程状态转为阻塞。此时操作系统不知道这是进程A的其中一个线程a,而把其视为进程A,从而无法进行进程A中从线程a到线程b的切换,而是直接切换到另一个进程B。导致整个进程A阻塞,进程A中的线程失去了并发性
1.3 用户级线程切换:
每个用户级线程拥有一个自己的栈。当用户级线程A切换到用户级B时,最关键的就是完成用户栈的切换:把运行当前线程A的cpu的esp的值装入到线程A的TCB中,并把线程B的TCB.esp赋值给CPU的esp。进而完成PC指针的切完从而完成线程的切换,使线程B占有CPU
二. 内核级线程
2.1 是什么
一个进程A的指令序列被分成n个,成为进程A的n个线程。
这n个线程分别拥有一个操作系统内核中的线程核心。
内核级线程对多核的支持:
一个进程(应用程序)运行时,其含有的多个线程因为分别拥有各自的核心线程,所以操作系统内核能够调度每一个线程,为其分配硬件资源,即CPU。
内核级线程的切换:
每一个内核级线程都有一套栈,包含用户栈与内核栈,因为内核栈中包括用户栈的一些信息,链接了用户栈,从而称这两个栈为一套栈。从内核级线程A切换到内核级线程B涉及到以下过程:(五段论)
用户栈A–中断指令—>内核栈A----线程阻塞,TCB切换–>内核栈B–中断返回–>用户栈。
注:
1.TCB切换与上文用户级线程中的TCB切换含义一致,
2.为线程B需要从内核栈返回用户栈: 应用程序大部分时间都在用户态执行,只有在需要高级权限,如I/O操作时才会进入内核态溜达一圈。