转:进程 线程 协程 管程 纤程 概念对比理解
3 月,跳不动了?>>> 引言 不知道是不是我自己本身就有那么一丝丝的密集恐惧,把这么一大堆看起来很相似很相关的概念放在一起,看起来是有点麻,捋一捋感觉舒服多了。 相关概念 任务、作业(Job,Task,Schedule) 在进程的概念出现之前,进程有着这样的称谓。 进程 为了使多个程序能够并发(同一时刻只有一个在运行,但感觉起来像多个同时运行;并行(同一时刻真的多个在运行,不是感觉像多个))的执行,操作系统需要一个结构来抽象和表示这个程序的运行。 进程是操作系统对一个正在运行的程序的一种抽象结构。 进程是指在操作系统中能独立运行并作为资源分配的基本单位,由一组机器指令、数据和堆栈等组成的能独立运行的活动实体。 操作系统可以同时运行多个进程,多个进程直接可以并发执行和交换信息。 进程在运行是需要一定的资源,如CPU、存储空间和I/O设备等。 线程 进程是资源分配的基本单位,进程的调度涉及到的内容比较多(存储空间,CPU,I/O资源等,进程现场保护),调度开销较大,在并发的切换过程效率较低。为了更高效的进行调度,提出了比进程更轻量的独立运行和调度的基本单位。 线程比进程更轻量 线程能独立运行,独立调度,拥有资源(一般是CPU资源,程序计数器等) 线程调度能大幅度减小调度的成本(相对于进程来说),线程的切换不会引起进程的切换 线程的引入进一步提高了操作系统的并发性,线程能并发执行