linux c 执行新程序
学习进程时,linu c上说新开的进程一般要执行另外一个程序,同时与父进程执行同一个程序没有意义
如下是如何执行一个新的程序
使用exec函数簇
exec函数簇包含如下函数
编写两个代码文件,其中使用exec_execve代码产生一个子进程来调用另一个程序processimage,代码如下
/**
*exec_execve.c
*/
#include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <sys/types.h> int main(int argc, char * const argv[], char ** environ) { /* code */ pid_t pid; int stat_val; printf("%s\n", "Exec example"); pid = fork(); switch( pid ) { case 0: printf("%s\n", "Child process is running now"); printf("My pid is:%d, My ppid is:%d\n", getpid(), getppid()); printf("My uid is:%d, My gid is:%d\n", getuid(), getgid()); //execve函数(const char * path, char * const argv[], char * const envp[]) //执行另外一个程序,进程就是当前的子进程,即当前的子进程执行了一个新的程序 execve("processimage", argv, environ); //当调用新的可执行程序之后,原有的子进程的映像被替换掉了,不再被执行,子进程永远不会执行到 //下面这条语句 printf("%s\n", "process never go to here"); exit(0); case -1: perror("process create failed\n"); //失败返回1 exit(1); default: //剩余的就是子进程的进程号 printf("parent process is running and pid is %d\n", getpid()); break; } wait(&stat_val); exit(0); }
/* * processimage.c */ #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <sys/types.h> int main(int argc, char const *argv[], char ** environ) { /* code */ int i; printf("%s\n", "I am process image"); printf("My pid is:%d, My pid is:%d\n", getpid(), getppid()); printf("My uid is:%d, My gid is:%d\n", getuid(), getgid()); for (i = 0; i < argc; i++) { printf("argv[%d] is: %s\n", i, argv[i]); } return 0; }
我们将这两个代码进行编译
gcc -o exec_execve exec_execve.c gcc -o processimage processimage.c
然后执行
./exec_execve test execve
结果如下
执行新程序后的进程保持了原来进程的pid, ppid,实际用户id,实际组id
另外还有当前工作目录,根目录,创建文件时使用的屏蔽字,进程信号屏蔽字,未决警告,和进程相关的使用处理器的时间,控制终端,文件锁