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