寫在前面:小生純業餘選手,開此博僅僅是爲了積累,純當筆記來用。如有看官光臨小生博客,請不要相信我的代碼就是正確的。如果您發現了錯誤也懇請耽誤您一點時間,請您在下面指出來,不勝感激!
如果發現一些筆記的說法完全是錯誤的請建議我刪除!
在多進程下文件讀寫是共享的,所以會產生如下問題:如何知道一個文件正在被其他進程讀寫?
回答:Linux通過文件鎖模型來解決這個問題。(文件鎖包括強制鎖與建議鎖)通過fcntl可以對文件加鎖(至於加的是什麼類型的鎖,要弄明白)
對於以上函數的解釋<來自某位網友>
函數說明:int fcntl(
int fd,//被加鎖的文件描述符號
int cmd,
//鎖的操作方式:F_SETLK(已經加鎖,異常返回) F_UNLK F_SETLKW(已經加鎖,則阻塞等待)
struct flock *lk//鎖的描述
)
struct flock是一個描述鎖的結構體
如下代碼來說明對文件加鎖,獲取文件鎖
加鎖程序,由於程序結束後內核會自動釋放文件鎖,所以這裏使用一個死循環(用來驗證相同的鎖是否可以被多次加在同一個文件上)
#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<fcntl.h>
int main()
{
int fd;
struct flock lk;
int r;
fd = open("a.txt",O_RDWR);
if( fd == -1 )
{
printf(":%m\n");
exit(-1);
}
lk.l_type = F_WRLCK;
lk.l_whence = SEEK_SET;
lk.l_start = 5;
lk.l_len = 10;
r = fcntl(fd,F_SETLK,&lk);
if(r == 0)
printf("add lock over!\n");
else
printf("add lock failed!\n");
while(1);
}
#include<stdio.h>
#include<stdlib.h>
#include<unistd.h>
#include<fcntl.h>
int main()
{
struct flock lk;
int fd = open("a.txt",O_RDWR);
if( fd == -1)
{
printf("::%m\n");
exit(-1);
}
int r = fcntl(fd,F_GETLK,&lk);
if( r == 0 )
{
printf("get lock over\n");
}
if(lk.l_type == F_WRLCK)
printf("get a write lock\n");
printf("start:%d,len:%d\n",lk.l_start,lk.l_len);
printf("PID:%d\n",lk.l_pid);
return 0;
}
1.一個文件是否可以被加多個鎖?
2.相同的鎖是否可以加在同一個文件上
3.詳細瞭解flock結構體