fork之后经常跟随着exec,即创建一个进程后就立马替换进程,所以并不执行一个父进程数据段、栈和堆的完全复制,因此这里使用的是写时拷贝技术。
我们使用程序来演示替换:
使用的程序代码类似演示父子进程的代码,但是子进程使用了exec进行替换。
代码仍然会出现父子进程的打印交替出现吗?
可以看到,父进程总共打印了七次,子进程直接被替换成了ps,并且没有打印信息。
这是因为,exec函数成功之后不会进行返回,失败才返回。
有了这个写时拷贝和成功不返回特性,就可以花费较少的资源创建一个新进程并进行替换了。