- 编写shell.
#include<stdio.h>
#include<unistd.h>
#include<sys/wait.h>
#include<stdlib.h>
#include<string.h>
void do_shell(int argc,char*argv[])
{
pid_t pid=fork();
if(pid==0){
if(execvp(argv[0],argv)==-1){
perror("execvp");
exit(1);
}
}
else
wait(NULL);
}
void do_parse(char*buf)
{
int argc=0;
char*argv[8];
int i;
int status=0;
for(i=0;buf[i] != 0;i++)
{
if(!isspace(buf[i]) &&status == 0)
{
argv[argc++]=&buf[i] ;
status=1;
}
else if(isspace(buf[i])){
status = 0;
buf[i] = 0;
}
}
argv[argc] =NULL;
}
3 封装fork/wait等操作, 编写函数 process_create(pid_t* pid, void* func, void* arg), func回调函数就是子进程执行的入口函数, arg是传递给func回调函数的参数. ???
4. popen/system, 这两个函数和fork的区别.
system 可以看做是fork + execl + waitpid
system在执行期间调用进程会一直等待shell命令执行完成(waitpid等待子进程结束)才返回,但是popen无须等待shell命令执行完成就返回了。我们可以理解system为串行执行,在执行期间调用进程放弃了”控制权”,popen为并行执行。
popen中的子进程没人给它”收尸”了,如果你没有在调用popen后调用pclose那么这个子进程就可能变成”僵尸”。