Linux子进程对父进程资源的“写时拷贝”
来源:互联网 发布:贵阳软件人均工资 编辑:程序博客网 时间:2024/05/16 17:09
Linux的fork()使用写时拷贝 (copy- on-write)实现。写时拷贝是一种可以推迟甚至避免拷贝数据的技术。内核此时并不复制整个进程的地址空间,而是让父子进程共享同一个地址空间。
Linux的fork()使用写时拷贝 (copy- on-write)实现。写时拷贝是一种可以推迟甚至避免拷贝数据的技术。内核此时并不复制整个进程的地址空间,而是让父子进程共享同一个地址空间。
Linux进程创建,子进程对父进程资源“写时拷贝”的证明
传统的fork()系统调用直接把所有的资源复制给新 创建的进程。这种实现过于简单并且效率低下,因为它拷贝的数据或许可以共享(This approach is significantly na?ve and inefficient in that it copies much data that might otherwise be shared.)。更糟糕的是,如果新进程打算立即执行一个新的映像,那么所有的拷贝都将前功尽弃。
Linux的fork()使用写时 拷贝 (copy- on-write)页实现。写时拷贝是一种可以推迟甚至避免拷贝数据的技术。内核此时并不复制整个进程的地址空间,而是让父子进程共享同一个地址空间。只 用在需要写入的时候才会复制地址空间,从而使各个进行拥有各自的地址空间。也就是说,资源的复制是在需要写入的时候才会进行,在此之前,只有以只读方式共 享。这种技术使地址空间上的页的拷贝被推迟到实际发生写入的时候。在页根本不会被写入的情况下---例如,fork()后立即执行exec(),地址空间 就无需被复制了。fork()的实际开销就是复制父进程的页表以及给子进程创建一个进程描述符。下列程序可证明写时拷贝:
#include <stdio.h>#include <sched.h>int data = 10;int child_process(){printf("Child process %d, data %dn",getpid(),data);data = 20;printf("Child process %d, data %dn",getpid(),data);while(1);}int main(int argc, char* argv[]){if(fork()==0) {child_process(); }else{sleep(1);printf("Parent process %d, data %dn",getpid(), data);while(1);}}
运行结果
Child process 6427, data 10
Child process 6427, data 20
Parent process 6426, data 10
第 1个Child process 6427, data 10是因为子进程创建时task_struct的mm直接拷贝自parent的mm;第2个Child process 6427, data 20是因为子进程进行了“写时拷贝”,有了自己的dataa;第3个Parent process 6426, data 10输出10是因为子进程的data和父进程的data不是同一份。
如果把上述程序改为:
#include <stdio.h>#include <sched.h>#include <stdlib.h>int data = 10;int child_process(){printf("Child process %d, data %dn",getpid(),data);data = 20;printf("Child process %d, data %dn",getpid(),data);while(1);}int main(int argc, char* argv[]){void **child_stack;child_stack = (void **) malloc(16384);clone(child_process, child_stack, CLONE_VM|CLONE_FILES|CLONE_SIGHAND, NULL);sleep(1);printf("Parent process %d, data %dn",getpid(), data);while(1);}
运行结果将是
Child process 6443, data 10
Child process 6443, data 20
Parent process 6442, data 20
由于使用了CLONE_VM创建进 程,子进程的mm实际直接指向父进程的mm,所以data是同一份。改变父子进程的data都会互相看到。
- Linux子进程对父进程资源“写时拷贝”
- Linux进程创建,子进程对父进程资源“写时拷贝”的证明
- Linux进程创建,子进程对父进程资源“写时拷贝”的证明
- Linux子进程对父进程资源的“写时拷贝”
- Linux进程创建,子进程对父进程资源“写时拷贝”
- fork后子进程对父进程资源的继承
- fork一个子进程会拷贝父进程的什么
- fork进程时资源的深拷贝和浅拷贝
- fork进程时资源的深拷贝和浅拷贝
- fork 后子进程copy父进程的什么资源
- Linux 进程--父进程查询子进程的退出状态
- Linux 进程--父进程查询子进程的退出状态
- 回收子进程的资源
- linux 进程的管理、子进程创建、进程资源的回收
- cygwin fork子进程对父进程数据的复制
- Linux内存管理之进程创建的写时拷贝技术
- Linux-证明子进程从父进程处拷贝了文件描述符
- 如何linux下监控进程及其子进程占用资源?
- Android:Intent Filter 和 action 简介
- ListView自适应实现表格
- 结婚
- ajax
- java数据结构----经典排序集锦
- Linux子进程对父进程资源的“写时拷贝”
- 通过存储过程 创建动态触发器
- Windows API 每日一练之 TrackMouseEvent
- Uva 216 Getting in Line
- POJ1724 ROADS(加限制条件的最短路,深搜)
- 读《设计模式》一
- ewf
- jstl表达式
- java A(A a)构造函数--原型构造函数