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结构体





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值