1.进程ID

每一个进程都由一个唯一的标识符表示,即进程ID,简称pid.系统保证在某时刻每个pid都是唯一的。

1.1分配进程ID

缺省情况下,内核将进程ID的最大值限制为32768,可以在此处设置/proc/sys/kernel/pid_max,在短时间内,内核不会重用已经分配的ID.

2.获得进程id和父进程id

  #include <stdio.h>
  #include <sys/types.h>
  #include <unistd.h>
  int main(){
          int pid=getpid();
          int ppid=getppid();
          printf("pid:%d ppid:%d \n",pid,ppid);
  }

 

3.运行新进程

首先创建新的进程fork()

在新的进程中执行程序exec系列的系统调用

4.exec系列的系统调用

execl()函数的原型为 int execl(const char *path,const char *arg,...)

path是程序路径,arg是传递给指定程序的可变长度参数列表,最后必须是null结尾

const 也可以和指针变量一起使用,这样可以限制指针变量本身,也可以限制指针指向的数据。

通常情况下execl()不会返回结果,成功的调用会以跳到新的程序的入口点作为结束,错误的时候会返回-1

         int ret;
         ret=execl("/usr/bin/vim","vim","text.txt",NULL);
         if(ret==1){
                 printf("execl error");
         }

 

5.fork()系统调用

创建一个和当前进程映像一样的进程可以通过fork()系统调用,调用者从fork()返回后,仍然继续运行。

当前进程就是父进程,创建成功的进程是子进程。

在父进程成功的fork()调用,会返回子进程的pid

在子进程fork()调用会返回0

#include <stdio.h>
#include <unistd.h>
int main(){
        int pid,ppid;

        int ret=fork();
        if(ret>0){
                pid=getpid();
                ppid=getppid();
                printf("我是父进程,pid=%d , ppid=%d ,我新建的子进程pid=%d\n",pi
d,ppid,ret);
                sleep(3);//父进程不能太快终止,否则看不出子进程ppid的效果
        }else if(ret==0){
                pid=getpid();
                ppid=getppid();
                printf("我是子进程,pid=%d , ppid=%d \n",pid,ppid);
        }else if(ret==-1){
                perror("fork");
        }   
}

我是父进程,pid=13890 , ppid=10038 ,我新建的子进程pid=13891

我是子进程,pid=13891 , ppid=13890