进程
什么是进程
进程(Process)是计算机中的程序关于某数据集合上的一次运行活动,是系统进行资源分配和调度的基本单位,是操作系统结构的基础。在早期面向进程设计的计算机结构中,进程是程序的基本执行实体;在当代面向线程设计的计算机结构中,进程是线程的容器。程序是指令、数据及其组织形式的描述,进程是程序的实体。摘自-百度百科
解释一下:
- 进程是计算机中的程序关于某数据集合上的一次运行活动意思是说当你运行一个程序的时候,你就启动了一个进程。
- 进程是系统进行资源分配和调度的基本单位,为某某资源分配了多少个进程
- 进程是程序的基本执行实体。意思是进程是正在运行的程序的实例
- 程序是指令、数据及其组织形式的描述,进程是程序的实体。
进程和程序的区别
- 程序是静态的,进程是动态的,只有当程序被cpu分配了进程,它才是关于某数据集合上的一次运行活动。
- 一个程序可以有多个不同的进程,多个不同的进程可以包含相同的程序
- 进程实体是由程序、数据和进程控制块(PCB)三部分组成
- 程序是永久的,进程是暂时的
- 进程具有创建其他进程的功能,而程序么有
线程
一个进程中可以包含若干个线程,
它们可以利用进程所拥有的资源,在引入线程的操作系统中,通常都是把进程作为分配资源的基本单位,而把线程作为独立运行和独立调度的基本单位,由于线程比进程更小,基本上不拥有系统资源
线程和进程的区别
打个比喻:
-
进程是一个工厂,工厂有它的独立资源
-
工厂之间相互独立
-
线程是工厂中的工人,多个工人协作完成任务
-
工厂内有一个或多个工人
-
工人之间共享空间
再完善完善概念: -
工厂的资源 -> 系统分配的内存(独立的一块内存)
-
工厂之间的相互独立 -> 进程之间相互独立
-
多个工人协作完成任务 -> 多个线程在进程中协作完成任务
-
工厂内有一个或多个工人 -> 一个进程由一个或多个线程组成
-
工人之间共享空间 -> 同一进程下的各个线程之间共享程序的内存空间(包括代码段、数据集、堆等)