无论是在批处理系统还是分时系统中,用户进程数一般都多于处理机数、这将导致它们互相争夺处理机。

另外,系统进程也同样需要使用处理机。
这就要求进程调度程序按一定的策略,动态地把处理机分配给处于就绪队列中的某一个进程,以使之执行。
linux进程调度基本属性:
1.多态性 从诞生、运行,直至消灭
2.多个不同的进程可以包括相同的程序
3.三种基本状态 它们之间可进行转换
4.并发性并发执行的进程轮流占用处理器
调度程序运行时,要在所有可运行状态的进程中选择最值得运行的进程投入运行。
在每个进程的task_struct结构中有以下四项:policy、priority、counter、rt_priority。
这四项是选择进程的依据。
其中,policy是进程的调度策略,用来区分实时进程和普通进程,实时进程优先于普通进程运行;
priority是进程(包括实时和普通)的静态优先级;
counter是进程剩余的时间片,它的起始值就是priority的值;
由于counter在后面计算一个处于可运行状态的进程值得运行的程度goodness时起重要作用,因此,counter也可以看作是进程的动态优先级。
rt_priority是实时进程特有的,用于实时进程间的选择。
linux tail命令用途是按照要求将指定的文件的最后部分输出到标准设备,通常是终端,通俗来讲,就是将某个档案文件的最后几行显示到终端上,假设该档案有更新,tail会自己主动刷新,确保你看到最新的档案内容。
1、linux是开放源代码的操作系统,可以让你知道系统是怎样工作;
2、Linux系统是由C语言写成的,可以让你领悟C语言的原理;
3、linux能当服务器,学好linux,可以进行服务器的维护或linux开发。
从计算机软件专业的角度上讲,计算机操作系统原理与我们编写计算机程序的关系当然相当密切了。尤其是作为一个学习的是计算机软件专业的人员,更应该做到:能够熟练编写计算机操作系统底层程序。
例如:假如说学习过计算机操作系统原理课程的话,那么肯定都知道老师必定要让同学们在 UNIX(或者是 Linux 系统)环境下,使用 fork( ) 编写多进程程序、以及经典的编程技能:P(S)、V(S)操作(不同进程之间的同步与互斥)。其中:P 操作代表申请一个资源、V 操作代表释放一个资源。S 为信号量 sem 的缩写。
Linux将虚拟存储器高端的1/4留给内核,剩下3/4全留给用户进程。虚拟存储器上中的程序主要由以下几个重要组成部分:
PCB中保存了进程hello的运行时的存储器图像和寄存器信息,它帮助操作系统在内存中找到我们的hello程序,如果没有它,hello只是和其它程序杂乱无章地分布在内存中就乱套了。
程序中的自动变量都位于栈上,而堆则用来让程序员自己手动分配(malloc)和释放(free)的内存空间,如果程序员忘了释放,则有垃圾收集器gc代劳。除此以外,栈还是程序转移中一个很重要的概念,程序的返回地址通常也保存在栈上。
所谓的文本段和数据段对应的就是程序的代码部分和全局变量,把程序的代码和数据分开处理是有好处的,比如我们在windows打开好几个Word,这些进程只是数据段不同罢了(它们都拥有相同的代码),因此内存中永远只要有一份word的代码就行了。
4.共享库的映射区域
操作系统通过将共享的对象映射到虚拟存储器的“共享区域”来使得代码能够共享,一方面提高存储器的利用率,一方面可以使得进程能够共享一些数据。