一、进程
定义:进程是运行中的程序。
状态:七种状态,从三个状态的运行、阻塞、就绪,再加两个状态—创建、退出,最后再加两个状态—就绪挂起、阻塞挂起。
进程的控制结构:PCB(进程控制块,进程存在的唯一标识),结构如下所示
进程描述信息 | 进程标识符、用户标识符 |
进程控制与管理信息 | 进程当前状态信息以及优先级信息 |
资源信息 | 有关地址空间信息、打开文件信息、IO设备信息 |
CPU相关信息 | CPU寄存器各值 |
进程的切换:进程的上下文切换不仅包含了虚拟内存、栈、全局变量等用户空间的资源,还包括了内核堆栈、寄存器等内核空间的资源。
二、线程
线程是调度的基本单位,是能独立运行的基本单位。
定义:线程是进程当中的一条执行流程。
线程优缺点:
优点 | 缺点 |
一个进程可以有多个线程 | 进程的一个线程崩溃会导致其所有线程崩溃(因为可能会导致内存不安全访问,所以直接崩溃) |
各个线程之间可以并发执行 | |
同一进程的线程可以共享地址和文件等 |
三、进程、线程的区别
1、进程是资源调度的基本单位,运行一个可执行程序会创建一个或多个进程,进程就是运行起来的可执行程序
2、线程是程序执行的基本单位,是轻量级的进程。每个进程中都有唯一的主线程,且只能有一个,主线程和进程是相互依存的关系,主线程结束进程也会结束。多提一句:协程是用户态的轻量级线程,线程内部调度的基本单位
3、进程的上下文切换不仅包含了虚拟内存、栈、全局变量等用户空间的资源,还包括了内核堆栈、寄存器等内核空间的资源
4、线程共享代码、数据、文件,独占栈和寄存器。线程之间可以并发运行且共享相同的地址空间
5、线程使用有一定难度,需要处理数据一致性问题(写直达,写回)
6、线程相对进程切换开销小,且线程、进程同步方式也不同。
7、进程数据共享复杂,需要用到进程间通信,但是同步简单
四、线程分类
1、用户线程
实现在用户空间的线程称为用户级线程。用户线程是完全建立在用户空间的线程库,用户线程的创建、调度、同步和销毁全由用户空间的库函数完成,不需要内核的参与,因此这种线程的系统资源消耗非常低,且非常的高效。
特点
- 用户线级线程只能参与竞争该进程的处理器资源,不能参与全局处理器资源的竞争。
- 用户级线程切换都在用户空间进行,开销极低。
- 用户级线程调度器在用户空间的线程库实现,内核的调度对象是进程本身,内核并不知道用户线程的存在。
缺点
- 如果触发了引起阻塞的系统调用的调用,会立即阻塞该线程所属的整个进程。
- 系统只看到进程看不到用户线程,所以只有一个处理器内核会被分配给该进程 ,也就不能发挥多核 CPU 的优势 。
- 当一个线程开始运行后,除非它主动地交出 CPU 的使用权,否则它所在的进程当中的其他线程无法运行,因为用户态的线程没法打断当前运行中的线程,它没有这个特权,只有操作系统才有,但是用户线程不是由操作系统管理的。
- 由于时间片分配给进程,故与其他进程比,在多线程执行时,每个线程得到的时间片较少,执行会比较慢;
2、内核线程
内核级线程是指内核线程建立和销毁都是由操作系统负责、通过系统调用完成的,内核维护进程及线程的上下文信息以及线程切换。
特点
- 内核级线程能参与全局的多核处理器资源分配,充分利用多核 CPU 优势。
- 每个内核线程都可被内核调度,因为线程的创建、撤销和切换都是对内核管理的。
- 一个内核线程阻塞与他同属一个进程的线程仍然能继续运行。
缺点
- 内核级线程调度开销较大。调度内核线程的代价可能和调度进程差不多昂贵,代价要比用户级线程大很多。
- 线程表是存放在操作系统固定的表格空间或者堆栈空间里,所以内核级线程的数量是有限的。
Linux线程实现
Linux 并没有为线程准备特定的数据结构,因为 Linux只有task_struct这一种描述进程的结构体。在内核看来只有进程而没有线程,线程调度时也是当做进程来调度的。Linux所谓的线程其实是与其他进程共享资源的轻量级进程。
为什么说是轻量级呢?在于它只有一个最小的执行上下文和调度程序所需的统计信息,它只带有进程执行相关的信息,与父进程共享进程地址空间 。
3、轻量级进程
轻量级线程 Light-weight Process简称LWP ,是一种由内核支持的用户线程,每一个轻量级进程都与一个特定的内核线程关联。
它是基于内核线程的高级抽象,系统只有先支持内核线程才能有 LWP。每一个进程有一个或多个 LWPs ,每个LWP 由一个内核线程支持,在这种实现的操作系统中 LWP 就是用户线程。
特点和缺点
由于轻量轻量级进程基于内核线程实现,因此它的特点和缺点就是内核线程的缺点,这里不再赘述。