现在的位置: 首页 > 综合 > 正文

exec()与system()的区别

2014年01月21日 ⁄ 综合 ⁄ 共 1090字 ⁄ 字号 评论关闭

这应该算是老生长谈的问题了,在此做一个记录。

执行exec()后,老的进程上下文将被exec出来的新的进程上下文覆盖,新进程代替原进程执行。

执行system()后则相当于fork()出一个子进程,并等待此子进程执行完毕。

请看如下程序以加深理解。

/* rt.c */  
int main()
{
     return 100;
}


#gcc rt.c -o rt

/* test.c */
#include <stdio.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>
#include <stdlib.h>

int main()
{
    char *argv[] = {NULL};
    char *envp[] = {NULL};
    int ret_stat = 0;
    int pid = fork();
    if (pid == 0) {
        printf("child: pid %d\n", getpid());
       //execve("./rt", argv, envp);
        execve("./rtabc", argv, envp);
        //system("./rt");
        exit(127);
    }
    else if (pid > 0 ) {
        printf("parent: child pid is %d\n", pid);
        if (waitpid(pid, &ret_stat, 0) != pid) {
            printf("waitpid failed, ret_stat is %d\n", ret_stat);
        }
        else {
            printf("waitpid success, ret_stat is %d\n", ret_stat);
            printf("WIFEXITED(ret_stat): %d; WEXITSTATUS(ret_stat): %d;", WIFEXITED(ret_stat), WEXITSTATUS(ret_stat));
        }


    }
    else if (pid < 0) {
        printf("fork() error !\n");
        exit(-1);
    }


    return 0;
}


宏WIFEXITED用于判断进程是否正常退出。

宏WEXITSTATUS用于得到进程的退出状态码。


分别使用execve()和system()函数来测试进程的返回值。

问:在列出的3种情况下,进程的返回值分别是什么?

1.使用execve("./rt", argv, envp);

返回值为100,execve()后的exit(127)永远都不会走到。


2.使用execve("./rtabc", argv, envp);

rtabc是一个并不存在的程序。

此时execve()函数将会执行失败。

最后进程返回127。


3.使用system("./rt");

进程返回127。

抱歉!评论已关闭.