一、通过系统调用创建进程-fork初识
认识fork
现象1:
现象2:
现象3:
为什么会出现这种现象呢?
说明不只一个人在运行,而是两个执行流在执行的。
本质上是fork之后产生两个执行流。
所以我们用fork来创建子进程,
二、父子进程代码共享,数据各自开辟空间,私有一份(采用写时拷贝)
如何理解fork创建子进程
1、目前我们创建进程的方式有:./cmd、run commend 、fork
但是在操作系统的角度来看,上面创建进程的方式,是没有差别的!!都是系统上面多了一个进程。
2、fork 的本质是创建了一个进程,那么操作系统上面就会多出一个进程;操作系统多出的这一个进程本质上就是在系统上面多出了一份与进程相关的内核数据结构+进程的代码和数据。
对于进程的代码和数据
当我们./cmd运行程序时,有对应得代码和数据。
我们fork时创建了子进程,但是我们并没有让子进程去额外的加载代码和数据,而是让他继续向后运行,那我们子进程对于的代码和数据呢?
默认情况下,会”继承“父进程的代码和数据!!对于与进程相关的内核数据结构
在内核数据结构satk_struct也会以父进程为模板,初始化子进程satk_strcut
所以对于子进程的理解
1、我们子进程的内核数据结构、子进程的PCB里面,有很多的属性是和父进程的一样。
2、子进程要执行的代码和数据要和父进程的一样或者类似。
3、fork之后,父进程代码和子进程代码是共享的!
那fork之前的代码会共享嘛?
会的,只不过不被执行罢了。注:
写时拷贝
按照语言的说法:代码是在代码区的和字符常量区是编码在一起的一个区,这个区域是不可以被修改的。
父进程和子进程代码是共享的,代码又是不能修改的。所以fork之后父子进程代码只有一份。
那数据呢?
默认情况下,数据也是共享的!不过需要考虑数据被修改的情况。一旦数据被修改就不是共享的了。
当数据被修改时
进程是具有独立性的;数据通过"写时拷贝"来完成进程的独立性。
三、fork有两个返回值
父子进程代码是共享的那我们创建子进程,就是为了和父进程干一样的事吗?
这样是没有意义的。
那如何让父子进程做不一样的事情呢?
我们是通过fork的返回值来完成的
fork失败返回<0
fork成功
给父进程返回子进程的pid
给子进程返回0观察现象
所以为了让父子进程做不一样的事情我们可以用if else来分流,让父子进程做不一样的事情。
注:fork之后父子谁先运行呢?这是不确定的!