今天我们来谈一谈Linux下的fork()函数
fork()函数需要的头文件 #include<unistd.h>
linux中的fork函数是非常重要的,它的作用为在一个已有的进程中创建一个新进程,新进程称为当前进程的子进程,当前进程称为新进程的父进程。fork函数创建子进程后,【1】系统会给子进程分配一块新的空间和内核数据结构,【2】然后将父进程的部分数据结构拷贝至子进程,【3】然后将子进程添加到系统的进程队列中,【4】最后fork函数返回,调度器开始调度(注意:子进程返回0,父进程返回子进程的pid(每个进程都有自己唯一的pid),fork后子进程和父进程谁先执行调度器说了算)
今天我只想着重谈一谈上面的第【2】条,将父进程的部分数据结构拷贝至子进程:
部分数据结构是哪部分呢,就是fork()函数之后的数据结构!意思是fork之后产生的父、子进程,父进程将全部代码执行一遍,而子进程只将fork()函数之后的代码执行一遍。就这个问题我们来看下代码、如下
执行结果:
我们确实看到了fork()函数之前的代码输出了一次,fork()函数之后的代码输出了两次。
接下来我们再看一个代码,如图
我们只是将fork()函数之前的输出语句中的"\n"去掉了,我们来看结果
如图,它居然输出了两条hello zhangmin!,两条hello word!,刚不是说子进程只执行fork()函数之后的代码吗?这是为什么?
原因是这样的,fork()函数之前的输出语句没加 \n,父进程将它输出时,暂时先放到了输出缓冲区(注意:输出都是先放到了输出缓冲区,输出缓冲区遇到\n后才将内容输出到屏幕),而系统给子进程拷贝fork()函数之后的代码时,同时也将输出缓冲区的内容拷贝一份(也就是图中的hello zhangmin!),所以才会出现第二个例子中的情况!
通过上述的讲解,希望大家能有所收获!
本人能力有限,如文中有错误,希望积极指出!
(CentOS7.5 x86_64)