新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 分析fork后多進程對文件的共享

分析fork后多進程對文件的共享

作者: 時間:2016-12-01 來源:網(wǎng)絡(luò) 收藏
fork函數(shù)是創(chuàng)建一個新的進程作為原進程的子進程,創(chuàng)建的子進程和父進程存在很多的相似性,首先父子進程的虛擬存儲空間的用戶空間是相同的,是將父進程的拷貝給子進程。同時父子進程對文件的操作是共享方式。因為父進程的文件描述符表被拷貝給了子進程(具體的原理參虛擬存儲器的內(nèi)容,私有對象寫時拷貝實現(xiàn)了父子進程之間形成相互獨立的地址空間)。因此父進程打開的所有文件描述符都在子進程中保存了(每個進程都有獨立的描述符表)。由于所有的進程共享文件表、v-node表,所以父子進程的描述符表也是相同的,所以父子進程對文件是以共享的方式存在的。
#include
#include
#include
#include
#include
#include
#include
int main()
{
int fd;
char c[3];
/*打開文件foobar.txt,采用的是只讀形式*/
fd = open("foobar.txt",O_RDONLY,0);
if(fork()==0)//子進程
{
read(fd,&c,2);/*讀文件的一個字節(jié)到c中*/
c[2]=