进程控制

  1. 编写shell.
#include
#include
#include
#include

#include
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那么这个子进程就可能变成”僵尸”。

你可能感兴趣的:(进程控制)