进程概念及应用
进程(process)
定义
占用内存空间的正在运行的程序;
- 从操作系统的角度看,进程是程序流的基本单位,若创建多个进程,则操作系统将同时运行。
- 进程是一个应用程序运行时刻的实例
- 从内存管理组件角度看,操作系统是给应用程序提供服务的。
- 进程必须要有一个地址空间,这个地址空间至少包括两部分内容:一部分是内核,一部分是用户的应用程序。
图示
内核提供服务的过程
通过停止应用程序代码运行,进入内核地址空间运行内核代码,然后返回结果。内核还需要记录一个应用程序都访问了哪些资源,比如打开了某个文件,或是访问了某个设备。而这样的“记录表”,我们就用“资源描述符”来表示。
应用程序和内核的关系
应用程序需要内核提供资源,而内核需要控制应用程序的运行。那么内核必须能够命令应用程序,让它随时中断(进入内核地址空间)或恢复执行,这就需要保存应用程序的机器上下文和它运行时刻的栈。
进程内部细节
- 进程的内核栈和进程的应用程序栈是两块内存空间,进程的权限表示一个进程是用户进程还是系统进程。进程的权限不同,它们能完成功能也不同。
- 建立进程就是在内存中建立起对应的数据结构的实例变量。建立进程的应用程序栈和进程的内核栈,进程地址空间等。
- 从中断入口处开始调用的函数,都是属于内核的函数
内核进程
用进程的方式去运行一段内核代码,那么这段代码就可以随时暂停或者继续运行,又或者和其它代码段并发运行,只是这种进程永远不会回到进程应用程序地址空间中去,只会在内核地址空间中运行。
进程是如何共享同一份内核代码和数据的?
每个进程都有一个内核栈,指向同一个块内核内存区域,共享一份内核代码和内核数据。内核进程一份页表,用户进程两份页表,用户进程多了一份用户空间页表,与其它用户进程互不干扰。
进程调度
进程的生命周期
一个进程从建立开始,接着运行,然后因为资源问题不得不暂停运行,最后退出系统。
进程僵死状态,表示进程将要退出系统不再进行调度
进程ID
无论进程是如何创建的,所有的进程都会从操作系统分配到ID。此数成为进程ID。
其值为大于2的整数。
1要分配给操作系统启动之后的首个进程(该进程协助操作系统)。
CPU核数和进程数
拥有2个运算设备的CPU称为双核(Daul)CPU。也就是说1个CPU内部可能包含多个运算设备(核)。
核的个数和可同时运行的进程数量相同。
若进程数过多,则进程将分时使用CPU资源,但是因为CPU运算极快,我们会感受到同时运行。核数越多,感觉越明显。
僵尸进程
**产生原因:**如果父进程没有主动要求获得子进程的结束状态值,操作系统将一直保存,并让子进程长时间处于僵尸进程状态。
将子进程边为僵尸进程的就是操作系统