Linux写时拷贝实现原理

        传统的fork系统调用直接把所有资源复制给新创建的进程,这种实现过于简单并且效率低下。
        写时拷贝指的是两个任务可以同时自由读取内存,但任意一个任务试图对内存进行修改时,内存就会复制一份提供给修改方单独使用,以免影响到其他的任务使用。
        Linux的fork()使用写时拷贝页实现。写时拷贝是一种可以推迟甚至免除拷贝数据的技术。内核此时并不复制整个进程地址空间,而是让父进程和子进程共享同一个拷贝。fork()只能够产生本任务的镜像,因此需要使用exec配合才能够启动别的新的任务。exec可以用新的可执行映像提花当前的可执行映像,因此在fork产生了一个新任务之后,新任务可以调用exec来执行新的可执行文件。fork和exec通常用于产生新任务,而如果要产生新线程,则可以使用clone.
         fork()的实际开销就是复制父进程的页表以及给子进程创建唯一的进程描述符。



猜你喜欢

转载自blog.csdn.net/kang___xi/article/details/80619435