(1)fork的内部原理:进程的分裂生长模式,如果操作系统需要一个新进程来运行一个程序,那么操作系统会用一个现有的进程来复制生成一个新进程。老进程叫父进程,复制生成的新进程叫子进程。子进程有自己独立的PCB子,被内核同等调度。
#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
int main(void)
{
pid_t p1 = -1;
p1 = fork(); // 返回2次
if (p1 == 0)
{
// 这里是子进程
printf("子进程, pid = %d.\n", getpid()); //打印子进程pid
printf("hello world.\n");
printf("子进程, 父进程ID = %d.\n", getppid()); //打印父进程pid
}
if (p1 > 0)
{
// 这里是父进程
printf("父进程, pid = %d.\n", getpid()); //打印父进程pid
printf("父进程, p1 = %d.\n", p1);
}
if (p1 < 0)
{
//出错
}
return 0;
}
(2)fork函数调用一次会返回2次,返回值等于0的就是子进程,而返回值大于0的就是父进程。
(3)典型的使用fork的方法:使用fork后然后用if判断返回值,并且返回值大于0时就是父进程,等于0时就是子进程。
(4)fork的返回值在子进程中等于0,在父进程中等于本次fork创建的子进程的进程ID。
4.父子进程对文件的操作
(1)**子进程继承父进程中打开的文件,**父进程先open打开一个文件得到fd,然后在fork创建子进程。之后在父子进程中各自write向fd中写入内容。
#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>
#include <stdlib.h>
int main(void)
{
// 首先打开一个文件
int fd = -1;
pid_t pid = -1;
fd = open("1.txt", O_RDWR | O_TRUNC);
if (fd < 0)
{
perror("ope