SA12226267
在linux中,有三种方式可以启动新进程:system系统调用,fork()以及exec函数簇。下面分别看看这三种方式:
1.system调用
Linux中system的源码如下:
int system(const char * cmdstring)
{
pid_t pid;
int status;
if(cmdstring == NULL)
return (1);
if((pid = fork())<0)
status = -1;
else if(pid == 0)
{
execl("/bin/sh", "sh", "-c", cmdstring, (char *)0);
-exit(127); //子进程正常执行则不会执行此语句
}
else
{
while(waitpid(pid, &status, 0) < 0)
{
if(errno != EINTER)
{
status = -1;
break;
}
}
}
return status;
}
当system接受的命令为NULL时直接返回,否则fork出一个子进程,因为fork在两个进程:父进程和子进程中都返回,这里要检查返回的 pid,fork在子进程中返回0,在父进程中返回子进程的pid,父进程使用waitpid等待子进程结束,子进程则是调用execl来启动一个程序代替自己,execl("/bin/sh", "sh", "-c", cmdstring,(char*)0)是调用shell,这个shell的路径是/bin/sh,后面的字符串都是参数,然后子进程就变成了一个 shell进程,这个shell的参数是cmdstring,就是system接受的参数
可以这样理解,system()执行情况如同在shell中执行如下命令 $sh -c string
有一个例子可以进一步说明:
写一个小程序test.c:
#include <stdio.h>
int main()
{
system("top");
return 0;
}
该程序运行结果如下;
效果相当于在shell下输入sh -c top命令
2.fork()
#include <sys/type.h>
#include <unistd.h>
pid _t fork(void)