1、fork函数运行 完成后,将会有两个进程在运行开始运行,在fork 函数后 将会 同时运行,包括子进程 和 父进程。
2、两个进程都将获得fork函数的相应的返回值,在父进程中返回值为是子进程的进程号。在子进程中获得的返回值为 0.
3、fork() 函数复制了父进程的中的代码断、数据段、堆栈段的大部分内容。系统开销及大,执行效率不高。
#include<sys/types.h>//基本系统数据类型 如:pid_t 进程ID和进程组ID
#include<unistd.h>//是POSIX标准定义的 Unix 类系统定义符号常量的头文件,包含了许多UNIX系统服务的函数原 //型,例如read函数、write函数和getpid函数
#include<stdlib.h>//包含了C、C++语言的最常用的系统函数
#include<iostream>
int main(void)
{
pid_t result; //这个为 进程 创建后的 返回值
result=fork(); //调用进程 创建函数
//fork函数运行 完成后,将会有两个进程在运行开始运行,在fork 函数后 将会 同时运行,包括子进程 和 父进程
std::cout<<"The value return by fork(): "<<result<<std::endl;
std::cout<<"Parent process ID: "<<getppid()<<std::endl;
if(result==-1)
{
std::cout<<"fork error!!"<<std::endl;
}
else if(result==0) //fork 函数返回值为0 则说明为 子进程
{
std::cout<<"Result =0 .The return value is "<<result<<std::endl;
std::cout<<"In child process!!"<<" My PID is "<<getpid()<<std::endl;
}
else
{
std::cout<<"Result !=0,-1.The return value is "<<result<<std::endl;
std::cout<<"In father process!!"<<"My PID is "<<getpid()<<std::endl;
}
return result;
}
运行结果:
///这一段为在 父进程中 运行的结果
The value return by fork(): 2242 //返回的值为子进程的进程号
Parent process ID: 2014 //这个为父进程的父进程的进程号
Result !=0,-1.The return value is 2242 //子进程的进程号
In father process!!My PID is 2241 //这个为本进程的进程号
这一段为在 子进程中的结果
The value return by fork(): 0 //返回值为0 ,说明当前的进程为 子进程
Parent process ID: 1 //父进程的进程号 被表示 为 1
Result =0 .The return value is 0 //返回值为0
In child process!! My PID is 2242 //这个子进程的进程号
这里得讲到进程的创建和死亡的过程,main函数退出后,也即父进程死亡了,因为它已经做完所有事情了。子进程就没有父进程了,这在操作系统是不被允许的,所以子进程的父进程就被置为p1了,p1是永远不会死亡的。