copy_on_write

转载 2012年03月23日 11:30:58

转:

http://blog.csdn.net/yanyiyyy/article/details/6532030

 

Linux中内存的管理和分配

Linux的页目录表和页表是在程序head.s中设置的.head.s程序在物理地址0处存放了一个页目录表,紧随其后的是4个页表.

page.s程序用于实现页异常中断处理过程,其中缺页和页写保护引起的中断分别调用memory.c的do_no_page()和do_wp_page()函数进行处理.do_no_page()会把需要的页面从块设备中取到内存指定位置处.在共享内存页面的情况下,do_wp_page()会复制被写的页面,同时取消页面的共享.

 

写时复制机制

为了节约物理内存,在调用fork()生成新进程时,新进程与原进程会共享同一内存区.只有当其中一进程进行写操作时,系统才会为其另外分配内存页面.这就是写时复制机制(copy on write)的意思.

当进程A使用系统调用fork创建一个子进程B时,由于子进程B实际上是父进程A的一个拷贝,因此会拥有与父进程相同的物理页面.为了节约内存和加快创建速度的目标,fork()函数会让子进程B以只读方式共享父进程A的物理页面.同时将父进程A对这些物理页面的访问权限也设成只读.这样,当父进程A或子进程B任何一方对这些已共享的物理页面执行写操作时,都会产生页面出错异常(page_fault int14)中断,此时CPU会执行系统提供的异常处理函数do_wp_page()来解决这个异常.

do_wp_page()会对这块导致写入异常中断的物理页面进行取消共享操作,为写进程复制一新的物理页面,使父进程A和子进程B各自拥有一块内容相同的物理页面.最后,从异常处理函数中返回时,CPU就会重新执行刚才导致异常的写入操作指令,使进程继续执行下去.

 

相关文章推荐

C++并发实战:面试题5:读者写者问题copy on write

读者写者问题 这也是一个非常经典的多线程题目,题目大意如下:有一个写者很多读者,多个读者可以同时读文件,但写者在写文件时不允许有读者在读文件,同样有读者读时写者也不能写。 这里...

写时拷贝技术(copy-on-write)

传统的fork()系统调用直接把所有的资源复制给新创建的进程。这种实现过于简单并且效率低下,因为它拷贝的数据也许并不共享,更糟的情况是,如果新进程打算立即执行一个新的映像,那么所有的拷贝都将前功尽弃。...

聊聊并发-Java中的Copy-On-Write容器(转载)

Copy-On-Write简称COW,是一种用于程序设计中的优化策略。其基本思路是,从一开始大家都在共享同一个内容,当某个人想要修改这个内容的时候,才会真正把内容Copy出去形成一个新的内容然后再改,...

标准C++类std::string的 内存共享和Copy-On-Write技术

1、概念 Scott Meyers在《More Effective C++》中举了个例子,不知你是否还记得?在你还在上学的时候,你的父母要你不要看电视,而去复习功课,于是你把自己关在房间里,做出一副...

Linux写时拷贝技术(copy-on-write)

http://www.cnblogs.com/biyeymyhjob/archive/2012/07/20/2601655.html Linux写时拷贝技术(copy-on-writ...

Linux写时复制技术(copy-on-write)

COW技术初窥:       在Linux程序中,fork()会产生一个和父进程完全相同的子进程,但子进程在此后多会exec系统调用,出于效率考虑,linux中引入了“写时复制“技术,也就是只有进程空...

copy-on-write详解

主要通过两个大神的博客来理解copy-on-write(COW)技术 1. std::string中的COW技术 (转自:http://blog.csdn.net/haoel/articl...

(转)Linux写时拷贝技术(copy-on-write)

Linux写时拷贝技术(copy-on-write) 转自:http://www.cnblogs.com/biyeymyhjob/archive/2012/07/20/2601655.html C...

Linux写时拷贝技术(copy-on-write)

COW技术初窥在Linux程序中,fork()会产生一个和父进程完全相同的子进程,但子进程在此后多会exec系统调用,出于效率考虑,linux中引入了“写时复制“技术,也就是只有进程空间的各段的内容要...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)