红联Linux门户
Linux帮助

linux c执行新程序

发布时间:2015-12-16 09:34:54来源:linux网站作者:孙悟坑

学习进程时,linu c上说新开的进程一般要执行另外一个程序,同时与父进程执行同一个程序没有意义

如下是如何执行一个新的程序

使用exec函数簇

exec函数簇包含如下函数

linux c执行新程序


编写两个代码文件,其中使用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

结果如下

linux c执行新程序

执行新程序后的进程保持了原来进程的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