fork采用操作系統提供的寫時復制(copy on write)機制,就是為了避免一次性拷貝大量內存數據給子進程造成阻塞。fork子進程時,子進程時會拷貝父進程的頁表,即虛實映射關系(虛擬內存和物理內存的映射索引表),而不會拷貝物理內存。這個拷貝會消耗大量cpu資源,并且拷貝完成前會阻塞主線程,阻塞時間取決于內存中的數據量,數據量越大,則內存頁表越大。拷貝完成后,父子進程使用相同的內存地址空間。
但主進程是可以有數據寫入的,這時候就會拷貝物理內存中的數據。如下圖(進程1看做是主進程,進程2看做是子進程):
在主進程有數據寫入時,而這個數據剛好在頁c中,操作系統會創建這個頁面的副本(頁c的副本),即拷貝當前頁的物理數據,將其映射到主進程中,而子進程還是使用原來的的頁c。