• 实现简易minishell


    目录

    1.shell简介

    2.逻辑实现过程

    3.实现思路

    4.代码实现

    5.测试用例及结果


    1.shell简介

    shell是命令行解释器,功能就是捕捉用户的输入,然后根据输入的信息运行指定的命令程序。

    2.逻辑实现过程

    (1)捕捉用户输入

    (2)字符串解析,得到命令名称和运行参数

    (3)创建子进程,并对子进程进行程序替换,设置运行参数

    (4)进程等待,防止子进程成为僵尸进程

    (5)循环上述操作

    3.实现思路

    (1)捕捉用户输入

    通过fgets函数读取用户输入保存到input字符数组中。

    注意:用户输入可能夹带空格,不能使用scanf函数进行输入捕捉。

    (2)字符串解析,得到命令名称和运行参数

    通过指针数组argv保存每一个操作或选项的字符首地址,并将每个操作或选项的末尾的下一个字符替换为'\0'。

    注意:argv末尾位置需要替换为NULL,以空作为参数结尾

    (3)创建子进程,并对子进程进行程序替换,设置运行参数

    通过pid对父子进程进行分流,利用execvp函数对子进程进行程序替换,让子进程运行对应的指令程序。

    注意:不能直接对minishell进行替换,因为替换后运行完新程序,进程就会退出;并且如果替换了minishell,在运行某个指令程序时崩溃,minishell也就崩溃了。因此需要创建子进程,通过子进程来运行指令程序。

    (4)进程等待,防止子进程成为僵尸进程

    通过wait方法,让父进程等待子进程运行完毕退出,防止子进程成为僵尸进程。

    (5)循环上述操作

    利用while循环进行上述操作。

    4.代码实现

    1. #include<stdio.h>
    2. #include<unistd.h>
    3. #include<string.h>
    4. #include<stdlib.h>
    5. #include<sys/wait.h>
    6. int main(){
    7. extern char** environ;//声明环境变量
    8. while(1){
    9. //1.捕捉用户输入
    10. printf("[username&hostname]$ ");
    11. fflush(stdout);//刷新缓冲区
    12. char input[1024]={0};
    13. fgets(input,1023,stdin);//从标准输入读取一行数据,数据不能大于1023字节
    14. input[strlen(input)-1]='\0';//将最后一个字符换为\0
    15. //2.字符串解析
    16. char* ptr=input;
    17. char* argv[32]={NULL};
    18. int argc=0;
    19. while(*ptr!='\0'){
    20. if(*ptr==' '){//查找第一个指令字符
    21. ptr++;
    22. continue;
    23. }
    24. argv[argc]=ptr;//保存指令地址
    25. argc++;
    26. while(*ptr!='\0'&&*ptr!=' '){//将末尾的下一个位置替换为'\o'
    27. ptr++;
    28. }
    29. *ptr='\0';
    30. ptr++;
    31. }
    32. argv[argc]=NULL;//以空作为参数结尾
    33. //3.创建子进程,进行程序替换
    34. pid_t pid=fork();
    35. if(pid==0){//子进程
    36. execvp(argv[0],argv);
    37. exit(-1);//替换失败则退出子进程,否则子进程会成为第二个minishel
    38. }
    39. wait(NULL);//等待子进程退出
    40. }
    41. return 0;
    42. }

    5.测试用例及结果

    测试用例1:“  ls -a"

    测试结果:

    测试用例2:”ls -l  “

    测试结果:

    测试用例3:”pwd"

    测试结果:

     

  • 相关阅读:
    2020 icpc 昆明 B. Chessboard 有源汇有上下界最小费用可行流 强制满流
    SpringBoot( 扩展篇 ==> 使用枚举完成前后端数据传输规范
    MS35774,高精度、低噪声的两相步进电机驱动芯片
    Unity开发者——编辑器技巧
    云计算高级课程作业
    半同态加密(Partially Homomorphic Encryption, PHE)
    文件系统系列专题之 Btrfs
    不碎片化学习,尽量用整块的时间系统化学习
    从零开发一款相机APP 第十篇:Camera2 zoom变焦
    初学者必备——三大类18条Java正则表达式语法
  • 原文地址:https://blog.csdn.net/m0_63020222/article/details/126582750