shell的工作原理以及模拟实现shell

来源:互联网 发布:magnet协议关联软件 编辑:程序博客网 时间:2024/06/03 20:13

1.什么是shell?

   Linux系统的shell作为操作系统的外壳,为用户提供使用操作系统的接口。它是命令语言、命令解释程序及程序设计语言的统称。

shell充当一个桥梁:
a.将使⽤者的命令翻译给核⼼(kernel)处理。
b. 同时,将核⼼的处理结果翻译给使⽤者。
这里写图片描述

2.shell的特性

(1)运行程序

   shell类似于一个程序启动器,shell将程序载入内存并运行它们。

(2)管理输入和输出

   使用<、>和|符号可以将输入输出重定向。这样就可以告诉shell将进程的输入和输出连接到一个文件或是其他进程。

(3)可编程

3.shell如何运行程序

shell用fork建⽴新进程,⽤execv函数簇在新进程中运⾏⽤户指 定的程序,最后shell⽤wait命令等待新进程结束。wait系统调 ⽤同时从内核取得退出状态或者信号序号以告知⼦进程是如何结束的。
这里写图片描述

4.按照上述流程模拟实现自己的shell

代码:

[cpp] view plain copy
print?
  1. #include <stdio.h>  
  2. #include <unistd.h>  
  3. #include <stdlib.h>  
  4. int main()  
  5. {  
  6.     while (1)  
  7.     {  
  8.         printf(”[SZK@localhost MyShell]#”);  
  9.         fflush(stdout);  
  10.         sleep(5);  
  11.         char cmd[128];  
  12.         ssize_t s = read(0, cmd, sizeof(cmd)-1);  
  13.         if (s>0)  
  14.         {  
  15.             cmd[s - 1] = ’\0’;  
  16.         }  
  17.         else  
  18.         {  
  19.             perror(”read”);  
  20.             return 1;  
  21.         }  
  22.         char *_argv[32];  
  23.         _argv[0] = cmd;  
  24.         char *start = cmd;  
  25.         int i = 1;  
  26.         while (*start)  
  27.         {  
  28.             if (isspace(*start))  
  29.             {  
  30.                 *start = ’\0’;  
  31.                 start++;  
  32.                 _argv[i++] = start;  
  33.             }  
  34.             else  
  35.             {  
  36.                 start++;  
  37.             }  
  38.         }  
  39.         _argv[i] = NULL;  
  40.         pid_t id = fork();  
  41.         if (id == 0)  
  42.         {//child  
  43.             execvp(_argv[0], _argv);  
  44.             exit(2);  
  45.         }  
  46.         else  
  47.         {//father  
  48.             int status = 0;  
  49.             pid_t ret = waitpid(id, &status, 0);  
  50.             if (ret>0 && WIFEXITED(status))  
  51.             {  
  52.                 //   printf(“wait success…exit code:%d\n”,WEXITSTATUS(status));   
  53.             }  
  54.             else  
  55.             {  
  56.                 //  printf(“wait filed..\n”);  
  57.                 return 3;  
  58.             }  
  59.         }  
  60.     }  
  61.     return 0;  
  62. }  

程序演示效果:
这里写图片描述

但是明显可以看到运行命令cd .. 并没有产生想要的效果,那是因为Shell执行的命令可以分为内建命令(built-in)和外部命令(external),前者是构建在shell内部;后者是一个独立的文件(可以是二进制文件,也可以是一个脚本)。而cd属于内建命令,而ls属于外部命令,执行比较复杂。内建命令的性能要优于外部命令,因为它没有新建进程的开销。

5.shell如何启动

   shell在你成功地登录进入系统后启动,并始终作为你与系统内核的交互手段直至你退出系统。你系统上的每位用户都有一个缺省的shell。每个用户的缺省shell在系统里的/etc/passwd文件里被指定。

6.附:exec用来程序替换的原理图

这里写图片描述

原创粉丝点击