学习进程时,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_tpid;
intstat_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
另外还有当前工作目录,根目录,创建文件时使用的屏蔽字,进程信号屏蔽字,未决警告,和进程相关的使用处理器的时间,控制终端,文件锁。
linux c/c++帮助:http://www.linuxdiyf.com/linux/15324.html
windows C与linux C区别?:http://www.linuxdiyf.com/linux/14068.html