码迷,mamicode.com
首页 > 系统相关 > 详细

linux c 执行新程序

时间:2015-12-13 23:40:40      阅读:270      评论:0      收藏:0      [点我收藏+]

标签:

学习进程时,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

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

linux c 执行新程序

标签:

原文地址:http://www.cnblogs.com/reddusty/p/5043721.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!