在Linux 中,创建一个新进程的唯一方法是有某个已存在的进程调用fork()函数,被创建的新进程称为子进程,已存在的进程称为父进程.
1.fork()函数
fork()函数的实质是一个系统调用(和write函数类似),其作用是创建一个新的进程,当一个进程调用它,完成后就出现两个几乎一模一样的进程,其中由fork()创建的新进程被称为子进程,而原来的进程称为父进程.子进程是父进程的一个拷贝,即子进程从父进程得到了数据段和堆栈的拷贝,这些需要分配新的内存;而对于只读的代码段,通常使用共享内存方式进行访问.
fork()的头文件 ”
#include
/*这是一个调用fork()函数创建子进程的实例,当创建成功之后会分别打印两者对应的进程标志符*/
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
int main(int argc,char *argv[])
{
pid_t pid; //进程标识符
pid = fork(); //创建一个新的进程
if(pid<0)
{
printf("创建进程失败!");
exit(1);
}
else if(pid==0) //如果pid为0则表示当前执行的是子进程
printf("这是子进程,进程标识符是%d\n",getpid());
else //否则为父进程
printf("这是父进程,进程标识符是%d\n",getpid());
return 0;
}
我自己的运行结果:
这是父进程,进程标识符是3014
这是子进程,进程标识符是3015
实例二:
/*这是一个调用fork()函数创建一个子进程,然后分别打印输出子进程和父进程中的变量的实例*/
#include <unistd.h>
#include <stdio.h>
#include <stdlib.h>
#include <errno.h>
int glob = 6;
int main(int argc,char *argv[])
{
int var; //内部变量
pid_t pid; //文件标识符
var = 88; //内部变量赋值
printf("创建新进程之前.\n"); //还没有创建子进程
if((pid=fork())<0)
{
perror("创建子进程失败!\n");
}
else if(pid==0)
{
glob++;
var++;
}
else
{
sleep(2); //父进程阻塞两秒
}
printf("进程标识符为=%d,glob=%d,var=%d\n",getpid(),glob,var);//分别在子进程中输出两个变量的值
exit(0);
}
运行结果:
创建新进程之前.
进程标识符为=3070,glob=7,var=89 //等待2秒
进程标识符为=3069,glob=6,var=88