对一个文件多个读写
来源:互联网 发布:java 线程池 如何使用 编辑:程序博客网 时间:2024/05/19 04:26
如果对一个文件多个读写怎么办?
Linux下多个进程或线程同时对一个文件进行写操作,如何解决冲突?
使用flock(锁定文件或解除锁定),简单可行!
先介绍一下flock函数吧
头文件 #include
定义函数 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 //flock header file
#include //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);
- 对一个文件多个读写
- 多个用户对一个文件操作
- Java 如何对文件进行多个Object对象流的读写操作
- 多线程实现对同一个或多个文件的读写操作
- Java 如何对文件进行多个Object对象流的读写操作
- Java 如何对文件进行多个Object对象流的读写操作
- Java —— 对文件进行多个Object对象流的读写操作
- 多个地方同时向一个文件读写的互斥问题解决方案
- chmod----改变一个或多个文件 的用户组 当前用户 其他用户的读写执行权限
- 对文件的读写;
- JS对文件读写
- C++连续读写多个文件
- C/C++ 连续读写多个文件
- 文件锁以及多路复用方式解决多个用户对一个文件的操作
- linux 多个用户对一个文件进行操作 文件锁和多路复用
- 文件锁以及多路复用方式解决多个用户对一个文件的操作
- c# 实现2个程序同时操作读写一个文件、一个读一个写
- shmget 共享内存 同步读写文件一个进程写,多个进程读,读和写同步,边写边读
- git常用知识点
- Jsoup使用小结
- leetcode No23. Merge k Sorted Lists
- Kylin资源加载的方式 一
- HTML 如何让元素可见性 设置为 不可见
- 对一个文件多个读写
- JS和JSP的区别?
- ADO.NET操作数据库(一)
- 超级密码 一脸蒙蔽中。。。。。
- 环形光的发光特征及其使用注意事项
- Linux初识第六天
- C++智能指针的理解与实现
- Java编程思想(第八章)
- 人工智能资料汇总--AI传送门