Ruby中的copy-on-write分叉

时间:2014-02-18 18:55:59

标签: ruby fork

我正在学习过程分叉,以及它是如何在Ruby中完成的。在我的阅读中,我已经了解了“写时复制”的行为。根据我的理解,在子线程尝试进行写操作之前,这基本上不会复制内存。这是否意味着当子进程确实尝试进行写入时,父内存被复制和修改,并且原始内存保持不变(因此父内存不受子进程的影响?)。感谢。

1 个答案:

答案 0 :(得分:6)

是。写时复制意味着只有两个进程相同的内存页保持共享。如果子进程或父进程写入其中一个共享页面,则将截取写入,将复制页面,并且写入将在仅由子/父进程拥有的新页面上进行。

值得一提的是,这与Ruby没有任何关系。 Ruby使用底层系统的fork系统调用,在Linux上和大多数UNIX上都有写入行为的副本。