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
- Linux信号前奏之文件锁
- 小白linux bash 学习前奏一 文件操作
- LINUX 信号之我见
- linux之信号
- Linux之信号
- linux IPC之信号
- Linux-IPC之信号
- linux 之进程信号
- Linux 之 信号
- linux信号之基本概念
- linux之信号
- linux之信号产生
- linux之信号阻塞
- linux之信号捕捉
- Linux 信号之mysleep
- linux编程之信号
- Linux信号机制之信号阻塞
- Linux C编程前奏
- eclipse 如何连接数据库(mysql)
- C#委托delegate与事件event
- 初学Python----urllib2模块与正则表达式组合而成的小爬虫
- php中GET POST REQUEST 的区别
- php自学笔记之windows开发环境的搭建
- Linux信号前奏之文件锁
- C# 线程间不能调用剪切板的问题
- nodejs mongoDB 视频教程
- 约瑟夫问题--list模拟循环链表
- Disruptor入门
- matlab学习笔记 图形句柄属性总结
- ARM linux解析之压缩内核zImage的启动过程 一
- csdn.net 的搜索功能
- 读书的建议