Linux信號前奏之文件鎖

寫在前面:小生純業餘選手,開此博僅僅是爲了積累,純當筆記來用。如有看官光臨小生博客,請不要相信我的代碼就是正確的。如果您發現了錯誤也懇請耽誤您一點時間,請您在下面指出來,不勝感激!

如果發現一些筆記的說法完全是錯誤的請建議我刪除!


在多進程下文件讀寫是共享的,所以會產生如下問題:如何知道一個文件正在被其他進程讀寫?

回答: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結構體





發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章