fork 进程测试 copy-on-write

父进程 fork 子进程后,子进程通过 copy-on-write 模式获得父进程内存,也就是子进程共用了大部分父进程内存,只有当子进程在修改自己进程内存后,共享部分,才会把那些修改的拷贝出来,这样可以节省系统大量内存分配。

🔥 文章来源:《fork 进程测试 copy-on-write


系统

macos


测试

测试对象申请一块内存,主进程 fork 子进程后监测子进程对内存数据修改前后状况。

子进程数据修改前

子进程数据修改后

测试进程跑得比较快,两次抓图的进程不一样。感兴趣的朋友可以拿源码测试下。


测试源码

源码

alloc_data g_data;

int main() {
    pid_t pid = fork();
    if (0 == pid) {
        printf("child pid: %d, data ptr: %#lx\n", getpid(),
               (unsigned long)&g_data);
        sleep(5);  // update data before
        printf("child pid: %d, reset data:\n", getpid());
        g_data.reset();
        sleep(5);  // update data later
        exit(0);
    } else if (pid > 0) {
        printf("parent pid: %d, data ptr: %#lx\n", getpid(),
               (unsigned long)&g_data);
    } else {
        printf("fork fail\n");
        exit(1);
    }

    printf("parent end, pid: %d\n", getpid());
    return 0;
}

测试结果

alloc, data ptr: 0x602140, array ptr: 0x602148
parent pid: 29118, data ptr: 0x602140
child pid: 29126, data ptr: 0x602140
child pid: 29126, reset data:
reset data, data ptr: 0x602140, array ptr: 0x602148
delete data, pid: 29126
child 29126 terminated normally with exit status = 0
sig_child_handler end, errno: 0
parent end, pid: 29118
delete data, pid: 29118
  1. 子进程拷贝父进程的数据,数据地址(虚拟地址)是一样的。
  2. 父进程 alloc 了一次数据,delete 了两次数据,子进程只是拷贝了父进程数据,没有跑父进程 fork 前的代码逻辑。
    3.子进程有自己的独立空间, 子进程修改数据后,copy-on-write,子进程空间将分配新的数据空间存储新数据(top 查看进程负载情况)。

参考

  • 《深入理解计算机系统》第二部分,8.4 章 进程控制

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值