线程:线程是在进程内部(地址空间内)运行的一个执行分支(执行流),属于进程的一部分,粒度比进程更细、更轻量化。
在其他的操作系统上,专门给线程设计了线程控制块。但在Linux中使用进程PCB来模拟线程。优点:无需单独为线程设计算法,直接利用进程的一套相关算法,OS只需聚焦在线程间的资源分配。
在还没有谈及多线程之前,我们所谈论的进程,内部都是单执行流的,也就是进程只有一个PCB。
今天的进程,内部可以具有多个执行流。
Linux使用进程PCB模拟线程:只创建task_struct(Linux进程PCB),共享同一个地址空间,将进程的资源分配给每个PCB使用。
其中的每个执行流就是线程,线程是CPU调度的基本单位,承担进程资源的部分实体;进程是资源分配的基本单位,承担分配系统资源的基本实体。
虽然从CPU的角度来看,调度的还是PCB,但是相对于传统进程要更为轻量化,所以在Linux中,线程又称为轻量级进程。
进程的线程共享同一个地址空间,除此之外还共享其他的资源:
- 文件描述符表
- 信号处理方式
- 当前工作目录
- 用户id、组id
虽然线程共享大部分的数据和资源,但是也有部分私有资源:
- 栈
- 信号屏蔽字
- 线程ID
- 调度优先级