在文已經(jīng)共享的情況下如何操作,也就是當多個進程同時操作同一個文件時,我們怎么保證文件數(shù)據(jù)的正確性。linux通常采用的方法是文件上鎖,來避免共享資源的產(chǎn)生競爭狀態(tài)。
文件鎖包括建議性鎖和強制性的鎖。建議性的,顧名思義,相對溫柔一些,在對文件進行鎖操作時,會檢測是否已經(jīng)有鎖存在,并且尊重已有的鎖。在一般的情況下,內核和系統(tǒng)都不使用建議鎖。強制性的鎖是由內核執(zhí)行的鎖,當一個文件被上鎖進行寫入操作的時候,內核將阻止其他進程對其進行讀寫操作。采取強制性的鎖對性能的影響很大,每次進行讀寫操作都必須檢查是否有鎖存在。
在linux中對文件進行鎖操作,可以使用lockf()和fcntl()這兩個函數(shù),前者對文件施加建議性鎖,后者為兩種鎖都行。另外fcntl還可以對文件的某一記錄上鎖。
fcntl使用格式為:
int fcntl(int fd,int cmd,struct flock *lock);
fd為文件描述符,cmd為一些命令參數(shù),flcok結構體用來設置記錄鎖的具體狀態(tài)。
fcntl() 對已打開的文件描述符進行操作,并根據(jù)命令參數(shù)的不同能夠執(zhí)行不同的任務。關于文件鎖的幾個命令選項如下:
F_UNLCK : 解除鎖定
l_start 為相對位移量
l_whence 必須是以下幾個值之一( 在 unistd.h 中定義):
SEEK_SET : 文件開始位置
SEEK_CUR: 文件當前位置
SEEK_END: 文件末尾位置
l_len 加鎖的長度
l_pid當前文件操作的進程id號
下面是簡單的例子
運行結果:
讀是可以共享的。
寫的例子:
運行結果:
同時寫的話,發(fā)生競爭,后者不能對文件做寫操作,只有當當前的鎖解開,后續(xù)的才可寫文件