fork函數是建立一個新的進程做爲原進程的子進程,建立的子進程和父進程存在不少的類似性,首先父子進程的虛擬存儲空間的用戶空間是相同的,是將父進程的拷貝給子進程。同時父子進程對文件的操做是共享方式。由於父進程的文件描述符表被拷貝給了子進程(具體的原理參虛擬存儲器的內容,私有對象寫時拷貝實現了父子進程之間造成相互獨立的地址空間)。所以父進程打開的全部文件描述符都在子進程中保存了(每一個進程都有獨立的描述符表)。因爲全部的進程共享文件表、v-node表,因此父子進程的描述符表也是相同的,因此父子進程對文件是以共享的方式存在的。
#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<sys/types.h>
#include<sys/stat.h>
#include<fcntl.h>
#include<sys/wait.h>
int main()
{
int fd;
char c[3];
/*打開文件foobar.txt,採用的是隻讀形式*/
fd = open("foobar.txt",O_RDONLY,0);
if(fork()==0)//子進程
{
read(fd,&c,2);/*讀文件的一個字節到c中*/
c[2]='\0';
printf("c = %s\n",c);
exit(0);
/*子進程結束*/
}
/*下面是父進程的讀操做*/
wait(NULL);
read(fd,&c,2);
c[2]='\0';
printf("c = %s\n",c);
exit(0);
}
其中foobar.txt中的內容是foobar。
編譯調試之後的結果是:
[gong@Gong-Computer cprogram]$ gcc -g fileshare2.c -o fileshare2
[gong@Gong-Computer cprogram]$ ./fileshare2
c = fo
c = ob
緣由分析:因爲父子進程是以共享的方式控制已經打開文件的,所以對文件的操做也是相互影響的,所以讀寫文件的位置也會發生相應的改變。父(子)進程的文件讀寫位置會隨着子(父)進程的文件讀寫位置改變而改變,由於此時改變的是文件表的文件位置項,而文件表是全部進程共享的,任何一個進程的修改都會影響到別的進程。可是父(子)進程對描述符的修改不會影響子(父)進程的描述符,由於close(fd)的操做只是改變文件表述符表中的內容,而該表是每一個進程相互獨立的,所以不會改變其餘進程的表。