Linux下多个进程或线程同时对一个文件进行写操作
来源:互联网 发布:肖凯农村淘宝 编辑:程序博客网 时间:2024/06/05 20:39
使用flock(锁定文件或解除锁定),简单可行!
先介绍一下flock函数吧
头文件 #include<sys/file.h>
定义函数 int flock(int fd,int operation);
函数说明 flock()会依参数operation所指定的方式对参数fd所指的文件做各种锁定或解除锁定的动作。此函数只能锁定整个文件,无法锁定文件的某一区域。
参数
operation有下列四种情况:
LOCK_SH 建立共享锁定。多个进程可同时对同一个文件作共享锁定。
LOCK_EX 建立互斥锁定。一个文件同时只有一个互斥锁定。
LOCK_UN 解除文件锁定状态。
LOCK_NB 无法建立锁定时,此操作可不被阻断,马上返回进程。通常与LOCK_SH或LOCK_EX 做OR(|)组合。
单一文件无法同时建立共享锁定和互斥锁定,而当使用dup()或fork()时文件描述词不会继承此种锁定。
返回值 返回0表示成功,若有错误则返回-1,错误代码存于errno。
上代码!
#include <sys/file.h> //flock header file
#include <unistd.h> //ftruncate header file
FILE *fin;
//读写打开一个文本文件,允许读和写
fin = fopen(szFile, "rt+");
if (!fin)
{
cout << "Fail to open the file: " << szFile << endl;
return;
}
//建立排他锁,阻塞方式
if ( (flock(fileno(fin), LOCK_EX)) < 0 )
{
cout << "Fail to lock the file: " << szFile << endl;
return;
}
本程序需要每次清空后重写
ftruncate(fileno(fin), 0); //清空文件
//写文件
......
//解除锁
if ( (flock(fileno(fin), LOCK_UN)) < 0 )
{
cout << "Fail to unlock the file: " << szFile << endl;
return;
}
fclose(fin);
- Linux下多个进程或线程同时对一个文件进行写操作
- Linux下多个进程或线程同时对一个文件进行写操作
- Linux下多个进程或线程同时对一个文件进行写操作
- Linux下多个进程或线程同时对一个文件进行写操作
- 解决Linux下多个进程或线程同时对一个文件进行写操作问题
- Linux下多个进程或线程同时对一个文件进行写操作
- Linux下多个进程或线程同时对一个文件进行写操作和access函数
- 同时对多个文件进行大量写操作对性能优化
- 同时对多个文件进行大量写操作对性能优化
- 【day16】写代码来解决多进程/线程同时读写一个文件的问题。
- 使用POI同时对Excel文件进行读和写操作时避免Invalid header signatu
- 线程同步的小例子(两个线程对一个List进行写操作)
- linux下多进程同时操作文件
- 对服务器端文件进行写操作
- 多进程同时写一个文件会怎样?
- JAVA多线程之两个线程同时写一个文件
- 一个读线程,一个写线程同时操作一个套接字
- C++实现线程同步的几种方式 线程同步是指同一进程中的多个线程互相协调工作从而达到一致性。之所以需要线程同步,是因为多个线程同时对一个数据对象进行修改操作时,可能会对数据造成破坏,下面是多
- 数据挖掘中所需的概率论与数理统计知识
- android Intent机制详解
- IBM推出新款企业电子邮件服务:整合社交媒体
- Egret学习入门
- Java用POI创建和读取导入EXCEL (一)
- Linux下多个进程或线程同时对一个文件进行写操作
- 摘自windows程序设计第五版
- android图标设计事宜
- 接触kendo ui
- rpmlib(FileDigests),rpmlib(PayloadIsXz) is needed解决办法
- IOS开发---菜鸟学习之路--(十五)-如何实现拍照功能
- .NET 客户端连接Redis 介绍
- css 生成图片
- Ajax请求的乱码问题