Linux下多个进程或线程同时对一个文件进行写操作
2016-10-19 14:37
351 查看
Linux下多个进程或线程同时对一个文件进行写操作,如何解决冲突?
使用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);
使用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下多个进程或线程同时对一个文件进行写操作和access函数
- Linux下多个进程或线程同时对一个文件进行写操作
- Linux下多个进程或线程同时对一个文件进行写操作
- Linux下多个进程或线程同时对一个文件进行写操作
- 解决Linux下多个进程或线程同时对一个文件进行写操作问题
- Linux下多个进程或线程同时对一个文件进行写操作
- C++实现线程同步的几种方式 线程同步是指同一进程中的多个线程互相协调工作从而达到一致性。之所以需要线程同步,是因为多个线程同时对一个数据对象进行修改操作时,可能会对数据造成破坏,下面是多
- linux下如何知道一个文件被哪个进程进行读写
- [Linux进程]在父进程和子进程中分别对文件进行操作
- 创建4个线程,4个线程同时对一个文件进行修改。线程1负责向文件写入A,线程2负责向文件写入B,线程3负责写入C,线程4负责写入D。最终文件里的内容应该是ABCDABCDABCD....循环10次;
- linux 多个用户对一个文件进行操作 文件锁和多路复用
- Linux&c 文件操作,线程进程控制,网络编程,简单知识点梳理
- Linux下两个进程可以同时打开同一个文件,这时如下描述错误的是:
- Linux shell 循环读入一个列表 文件 进行操作
- 递归遍历一个文件夹,对文件进行操作,使用lstat时的悲剧
- Linux 下如何真正地删除一个正在被进程独占的文件
- Linux下对文件进行相关的操作
- 使用java类SequenceInputStream 对一个文件进行分割和合并的操作
- 一个进程能够打开最大文件句柄数设到多大才合适(Linux) (转)
- linux用文件锁实现保证一个程序只能启动一个进程