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

另外还有当前工作目录,根目录,创建文件时使用的屏蔽字,进程信号屏蔽字,未决警告,和进程相关的使用处理器的时间,控制终端,文件锁

posted @ 2015-12-13 22:13  孙悟坑  阅读(627)  评论(0编辑  收藏  举报