一.fork
1.函数原型
pid_t fork(void);
2.函数功能
创建一个子进程。
3.返回值
失败返回-1,成功父进程返回子进程的id,子进程返回0。
4.函数头文件
#include <sys/types.h>
#include <unistd.h>
5.进程的创建
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(int argc, char *argv[])
{
pid_t pid = fork();
if(pid == -1)
{
perror("fork");
return -1;
}
else if(pid == 0)
{
printf("child:%d\n",getpid());
}
else
{
printf("parent:%d\n",getpid());
sleep(1);
}
return 0;
}
运行结果

注意:
1.运行程序的时候,父进程与子进程谁先运行是随机的。绝大多数情况下是父进程先运行,这是因为绝大多数情况下父进程在创建子进程后时间片还没有用完。
2.如果子进程还没有结束,这时候父进程结束了,这个时候子进就成为了孤儿进程,由系统init收留。
二.vfork
1.函数原型
pid_t fork(void);
2.函数功能
创建一个子进程,并且阻止父进程。
3.返回值
失败返回-1,成功父进程返回子进程的id,子进程返回0。
4.函数头文件
#include <sys/types.h>
#include <unistd.h>
5.进程的创建
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(int argc, char *argv[])
{
pid_t pid = vfork();
if(pid == -1)
{
perror("fork");
return -1;
}
else if(pid == 0)
{
printf("child:%d\n",getpid());
}
else
{
printf("parent:%d\n",getpid());
sleep(1);
}
return 0;
}
运行结果

注意:vfork创建子进程后,父子进程的进程顺序就有了变化不像fork看缘分,vfork后程序先运行子进程,随后再去执行父进程。
vfork需要保证子进程先与父进程执行,不然就会被锁死,这个就需要用exec或_exit之后父进程才可能被调度运行。
在子进程加入一个exit(0)就可以实现。
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
int main(int argc, char *argv[])
{
pid_t pid = vfork();
if(pid == -1)
{
perror("fork");
return -1;
}
else if(pid == 0)
{
printf("child:%d\n",getpid());
exit(0);
}
else
{
printf("parent:%d\n",getpid());
sleep(1);
}
return 0;
}

重点:
fork()函数 父子进程都有各自独立空间;父子执行顺序随机。
vfork()函数 子进程刚开始暂时与父进程共享地址空间;必须子进程先执行。
267

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



