作为中断处理的另一个示例,下面介绍linux系统中shell命令的一般执行过程。
Linux系统提供给用户的最重要的系统程序是shell命令语言解释程序。它不属于内核部分,而是在核心之外以用户态方式运行。
其基本功能是解释并执行用户输入的各种命令,实现用户与Linux核心的接口。系统初启后,核心为每个终端用户建立一个进程去执行shell解释程序。它的执行过程基本上按照如下步骤进行:
(1)读取用户由键盘输入的命令行。
(2)分析命令,以命令名作为文件名,其他参数改造为系统调用execve( )内部处理所要求的形式。
(3)终端进程调用fork( )建立一个子进程。
(4)终端进程本身用系统调用wait4( )来等待子进程完成(如果是后台命令,则不等待)。当子进程运行时调用execve( ),子进程根据文件名(即命令名)到目录中查找有关文件(这是命令解释程序构成的文件),调入内存,执行这个程序(即执行这条命令)。
(5)如果命令末尾有&号(后台命令符号),则终端进程不用执行系统调用wait4( ),而是立即发提示符,让用户输入下一个命令,转步骤(1)。
如果命令末尾没有&号,则终端进程要一直等待,当子进程(即运行命令的进程)完成工作后要终止,向父进程(终端进程)报告,此时终端进程醒来,在做必要的判别等工作后,终端进程发提示符,让用户输入新的命令,重复上述处理过程。
shell命令基本执行过程
以上介绍的仅是shell作为命令解释程序的基本工作原理,其实际工作过程是很复杂的。
既便如此,我们从中也可以体会到:进程是动态活动的,父子进程间构成族系,彼此间有同步关系,进程间的切换是由进程调度程序实现的。大家如果有兴趣的话,可结合上机实习,深入想一想命令的执行过程。