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