fork函数包含在头文件 #include<unistd.h> 中
fork函数用于创建一个新进程,称为子进程,它与进程(称为系统调用fork的进程)同时运行,此进程称为父进程。创建新的子进程后,两个进程将执行fork()系统调用之后的下一条指令。子进程和父进程的执行顺序不确定,不是说谁一定先执行。
子进程使用相同的pc(程序计数器),相同的CPU寄存器,在父进程中使用的相同打开文件。
fork函数是有返回值的,父进程的fork()的返回值是子进程的pid ,而子进程的fork()的返回值是 0(可以理解为子进程没有它的子进程所以返回值是0),还有可能返回值是 -1,这代表fork()出现了错误。
错误的原因有三种可能:
1) 系统内存不够
2) 进程表满(容量一般为 200~400)
3) 用户的子进程太多(一般不超过 25 个)
示例1:
#include<unistd.h>
int main(){
pid_t fpid;
int count = 0;
fpid = fork();
if(fpid<0){
printf("Error !\n");
}else if(fpid == 0){
printf("Son process ! Pid = %d\n",getpid());
count++;
}else{
printf("Father process ! Pid = %d\n",getpid());
count++;
}
printf("count = %d\n",count);
return 0;
}
结果:

示例2:
#include<unistd.h>
#include<stdio.h>
int main(){
int i = 0;
for(i = 0;i < 3;i++){
pid_t fpid = fork();
if(fpid == 0)
printf("Son\n");
else
printf("Father\n");
}
return 0;
}
结果:

实例3:
请画出一下代码运行后的进程关系
fork()
fork()
fork()
fork()

实例四:
要求父进程产生两个子进程,父进程输出从1到6 ,子进程1 输出从a 到 f ,子进程2 输出从 A 到 F,要求按aA1类似的交替输出
#include<stdio.h>
#include<unistd.h>
int main(){
int p = fork();
int q;
if(p){
q = fork();
if(q){
int i=1;
printf("this is the father! Pid = %d\n", getpid());
while(i<=6){
printf("%d",i++);
fflush(stdout);
sleep(1);
}
}else{
char c='a';
printf("this is child2 ! pid = %d\n" ,getpid());
while(c<='f'){
printf("%c\n",c++);
sleep(1);}
}
}else{
char c='A';
printf("this is child1 ! pid = %d\n",getpid());
while(c<='F'){
printf("%c\n",c++);
sleep(1);}
}
return 0;
}

这里如果没有再输出后面加上"\n"的话是不会交替输出的,而还是整个进程整个进程的输出,当加上"\n"是才可以交替输出。这里"\n"的作用就是刷新行缓冲区,
行缓冲,大小是一行,加了回车就是一行了
Fflush(stdout)函数的作用也是清空缓冲区
本文详细解析了fork函数的原理及应用,包括其在系统调用中的作用,如何创建子进程,以及子进程与父进程之间的关系。通过示例代码展示了fork函数的返回值和常见错误原因,帮助读者掌握进程管理的基础。
1263

被折叠的 条评论
为什么被折叠?



