什么是进程
进程是一种操作系统中非常重要的软件资源。把一个可执行程序跑起来,系统中就会创建一个对应的进程.如果这个程序执行结束了,系统就会随之销毁对应的进程。进程就可以看成是一个程序的执行的“过程”
对于操作系统来说,一个任务就是一个进程(Process)。进程是担当分配系统资源(CPU时间,内存)的实体,是系统分配资源的最小单位,是程序组成的实际单位,是具有动态特性的。
进程就是可执行文件吗?
不是。挡把一个可执行文件加载到内存当中,运行起来之后,可执行文件就变成了一个进程。
时间片
现代操作系统比如Mac OS X,UNIX,Linux,Windows等,都是支持“多任务”的操作系统。所谓的多任务,就是操作系统可以同时运行多个任务。操作系统(如Windows、Linux)的任务调度是采用时间片轮转的抢占式调度方式,也就是说一个任务执行一小段时间后强制暂停去执行下一个任务,每个任务轮流执行。任务执行的一小段时间叫做时间片,任务正在执行时的状态叫运行状态,任务执行一段时间后强制暂停去执行下一个任务,被暂停的任务就处于就绪状态等待下一个属于它的时间片的到来。这样每个任务都能得到执行,由于CPU的执行效率非常高,时间片非常短,在各个任务之间快速地切换,给人的感觉就是多个任务在“同时进行”,这也就是我们所说的并发。这样每个任务都能得到执行,由于CPU的执行效率非常高,时间片非常短,在各个任务之间快速地切换,给人的感觉就是多个任务在“同时进行”,这也就是我们所说的并发。
并发与并行
- 并发:多个进程在一个CPU下采用时间片轮转的方式,在一段时间之内,让多个进程都得以推进,称之为并
发。 - 并行:多个进程在多个CPU下分别,同时进行运行,这称之为并行。
计算机操作系统中把并行性和并发性明显区分开,主要是从微观的角度来说的,具体是指进程的并行性(多处理机的情况下,多个进程同时运行)和并发性(单处理机的情况下,多个进程在同一时间间隔运行的)。
并发与并行类似于工厂中的流水线,要扩大产量,1是考虑建造多个工厂,这就是并行,2是考虑每个工厂中新增流水线,这就类似并发。
内核态与用户态
用户态和内核态是操作系统(如Windows、Linux)对执行权限进行的等级分级。
- 内核态:操作系统内核作为直接控制硬件设备的底层软件,权限最高,称为内核态,或核心态(一般操作硬件的代码都是内核态的)。
- 用户程序的权限最低,称为用户态,即执行自己的程序。
类比于生活中的存钱,我们能看到的操作比如交钱给卡等这就相当于代码在用户态执行,而银行的工作人员在电脑上的操作客户是看不到的,这就相当于代码在内核态执行。
进程中的上下文
可以说上下文就是一个环境,进程在时间片轮转切换时,由于每个进程运行环境不同,就涉及到转换前后的上下文环境的切换。
- 上下文就是一个进程在执行的时候,CPU的所有寄存器中的值、进程的状态以及堆栈上的内容。
- 进程切换时需要保存当前进程的所有状态,即保存当前进程的进程上下文,以便再次执行该进程时,能够恢复切换时的状态,继续执行。
进程的状态以及转换
- new 线程创建好了,但是还没有启动
- runnable,线程启动(也就是调用了start方法),CPU正在执行,包括、ready和running两个状态
- ready:就绪态:进程处于可运行的状态,只是CPU时间片还没有轮转到该进程,则该进程处于就绪状态。
- running运行态:进程处于可运行的状态,且CPU时间片轮转到该进程,该进程正在执行代码,则该进程处于运行状态。执行yield方法时,让出CPU,进入ready态
- blocked:阻塞:进程不具备运行条件,正在等待某个事件的完成
- terminated:程序正常执行完毕
- waiting:等待;
- timedWaiting:超时等待,有具体的得等待带时间。
pid
进程的身份标识,pid不是惟一的,例如你登录QQ时有一个pid,当你退出再次登录时也会有一个新的pid,这两个pid是不一样的。
一个进程的状态
R:就绪状态,正在 CPU上执行,或者即将执行
S:睡眠状态:这些进程没法在 CPU上执行,而是在等待.
D:深度睡眠状态:进程在长时间的忙于IO操作,没精力理会CPU
X:退出状态:进程巴经被销毁了