Linux信号前奏之文件锁

来源:互联网 发布:nodejs和java的区别 编辑:程序博客网 时间:2024/06/03 17:47

写在前面:小生纯业余选手,开此博仅仅是为了积累,纯当笔记来用。如有看官光临小生博客,请不要相信我的代码就是正确的。如果您发现了错误也恳请耽误您一点时间,请您在下面指出来,不胜感激!

如果发现一些笔记的说法完全是错误的请建议我删除!


在多进程下文件读写是共享的,所以会产生如下问题:如何知道一个文件正在被其他进程读写?

回答: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结构体





0 0
原创粉丝点击