Linux下多个进程或线程同时对一个文件进行写操作

来源:互联网 发布:最优化导论 第四版pdf 编辑:程序博客网 时间:2024/06/06 03:52
 http://apps.hi.baidu.com/share/detail/19901173

Linux下多个进程或线程同时对一个文件进行写操作,如何解决冲突?

使用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);

来自: http://hi.baidu.com/ablenavy/blog/item/a78a550fad16f4276159f3a7.html
原创粉丝点击