关于一个简单的shell的实现
题目是操作系统书上的,很无聊,就做了做!
做的时候遇到了一些问题,查了一些资料,现在集中展现一下。
1.关于exec族
execvp
表头文件:
#include<unistd.h>
定义函数:
int execvp(const char *file ,char * const argv []);
函数说明:
execvp()会从PATH 环境变量所指的目录中查找符合参数file 的文件名,找到后便执行该文件,然后将第二个参数argv传给该欲执行的文件。
返回值:
如果执行成功则函数不会返回,执行失败则直接返回-1,失败原因存于errno中。
execl
表头文件:
Windows下头文件:#include <process.h>函数定义:
int execl(const char *path, const char *arg, ...);
函数说明:
execl()其中后缀"l"代表list也就是参数列表的意思,第一参数path字符指针所,指向要执行的文件路径, 接下来的参数代表执行该文件时传递的参数列表:argv[0],argv[1]... 最后一个参数须用空指针NULL作结束。
返回值 :
成功则不返回值, 失败返回-1, 失败原因存于errno中,可通过perror()打印。
如果执行成功则函数不会返回,执行失败则直接返回-1,失败原因存于errno中。
如果执行成功则函数不会返回,执行失败则直接返回-1,失败原因存于errno 中。
2.关于为什么要创建子进程运行输入命令的原因!
先看下面一段代码:
#include <stdio.h>#include <unistd.h>//#define SIZE 20#define MAXLINE 80char *p;void setup (char inputBuffer[], char *argv[]){ int i, j; i = 0; for (p = inputBuffer; ;p++)/*一个一个地将输入字符分开*/{argv[i++] = p;while (*p != ' ' && *p != '\0')p++;if (*p == '\0'){break;}*p = '\0'; } argv[i] = NULL; pid_t pid pid = fork();/*新建一个子进程*/ if (pid == 0)/*对于子进程,执行输入的命令*/ { execvp (argv[0], argv); printf ("command not found\n");/*如果execvp执行失败的话,会返回-1,也就是这句话会被执行*/ } else if( pid > 0 )/*对于父进程,等待*/ { wait(NULL);/*父进程等待子进程执行完*/ } else /*否则的话,就出错了*/ { printf ("fork error\n"); }}int main(){char inputBuffer[MAXLINE];char *argv[MAXLINE / 2 - 1];while (1){printf ("COMMAND->"); gets (inputBuffer);/*关于scanf和gets,scanf对于输入的字符遇到空格或回车就结束了,而gets对于输入的空格也接受*/setup (inputBuffer, argv);}return 0;}