1.例如ls
我们在当前的shell终端上,运行我们所写的程序,shell会先进行fork,创造出一个和shell一模一样的进程,然后立即执行exec操作,摇身一变,运行。
此时shell就在等待该进程结束,wait。

在prime1中,我们没有添加wait操作,所以当父进程创建完进程之后,就返回了,父进程创造的所有的子进程都变成了孤儿进程,被init接管,所以会先显示出终端的内容
为什么被init进程接管后,还会在终端上输出呢?
因为父进程的文件描述符中,至少会默认打开三个 0 1 2 stdin stdout stderror
然后子进程会进行拷贝,所以会在上面输出
2.进程之间通信
那么我们通过这里 , 就可以知道 父进程手握一个文件描述符,然后fork一个子进程,那么父子进程都手握同一个文件描述符,那么父进程向里面写入一个内容,子进程读取一个内容,那么不就是进程之间进行通信了吗?
3.一个简单的shell
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <glob.h>
#include <string.h>
#define DELIMS " \t\n"
void prompt(void)
{
printf("Mysh-0.1$ ");
}
void parse(char * Line, glob_t * GlobRes)
{
char *tok;
int i = 0;
while(1)
{
tok = strsep(&Line, DELIMS);
if(NULL == tok)
break;
if('\0' == tok[0])
continue;
glob(tok, GLOB_NOCHECK|GLOB_APPEND*i, NULL, GlobRes);
i = 1;
}
}
int main()
{
pid_t pid;
char *LineBuf = NULL;
size_t BufSize = 0;
glob_t GlobRes;
while(1)
{
prompt();
if(getline(&LineBuf, &BufSize, stdin) < 0)
break;
parse(LineBuf, &GlobRes);
if(0)
{}
else
{
pid = fork();
if(fork < 0)
{
perror("fork()");
exit(1);
}
if(0 != pid)
{
wait(NULL);
globfree(&GlobRes);
}
else
{
execvp(GlobRes.gl_pathv[0], GlobRes.gl_pathv);
perror("execvp()");
exit(1);
}
}
}
return 0;
}

被折叠的 条评论
为什么被折叠?



