进程
- 进程是程序的一次执行过程,是一个动态概念。
- 是分配和管理资源的基本单位。
- 进程的五个状态:初始态、执行态、等待状态、就绪态、终止状态。
线程
- 是CPU调度和分派的基本单位。
- 线程可以与同属于一个进程的其他线程共享进程所拥有的全部资源。
联系
在操作系统中能同时运行多个进程(程序);而一个进程(程序)中有多个线程同时执行。
区别
- 根本区别:进程作为系统资源分配的基本单位;线程是任务调度和执行的基本单位。
- 开销方面:每个进程都有独立的代码和数据空间(程序上下文),程序之间有较大的开销;线程可以看做轻量级的进程,同一类线程共享代码和数据空间,每个线程都有自己独立的运行栈和程序计数器(PC),线程之间切换的开销小。
- 所处环境:在操作系统中能同时运行多个进程(程序),而在同一个进程(程序)中能有多个线程同时执行。
- 内存分配:系统在运行的时候会为每个进程分配不同的内存空间;而对线程而言,除了CPU外,系统不会为线程分配内存(线程所使用的资源来自其所属进程的资源),线程组之间只能共享资源。
- 包含关系:没有线程的进程可以看做是单线程的,如果一个进程内有多个线程,则执行过程不是一条线的,而是多条线(线程)共同完成的;线程是进程的一部分,所以线程也被称为轻权进程或者轻量级进程。