Linux下多个进程或线程同时对一个文件进行写操作
来源:互联网 发布:猎豹浏览器网络异常 编辑:程序博客网 时间:2024/05/16 16:00
使用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++实现线程同步的几种方式 线程同步是指同一进程中的多个线程互相协调工作从而达到一致性。之所以需要线程同步,是因为多个线程同时对一个数据对象进行修改操作时,可能会对数据造成破坏,下面是多
- win7一直检查更新解决方法
- 蒙特卡罗(Monte Carlo)
- 二进制文件复制
- android中的windowTranslucentStatus和fitsSystemWindows的作用
- struts2 action接收文件上传数据处理
- Linux下多个进程或线程同时对一个文件进行写操作
- NoClassDefFoundError
- 注释插件VVDocumenter-Xcode in Xcode8
- 关于settimeout
- bzoj 2141 线段树套权值线段树
- JQuery解析xml的两种方式$.get和$.ajax
- synchronized详解
- 网络安全行业全景图
- li标签的横向排列