LINUX多线程读写同一个文件 加锁
来源:互联网 发布:大数据探索性分析 编辑:程序博客网 时间:2024/05/01 11:14
当有多个工作线程要同时对一个文件进行写操作时,如果不对该文件进行加锁就可能会因误操作而引起一系列的问题。
解决这个问题有多种方法。我们这里考虑使用文件锁来对文件进行保护,因为这个方法简单易行。具体方法是使用Flock函数进行加锁:
if((flock(fd, LOCK_EX | LOCK_NB))< 0)
{
std::cout<<"Log::The log have been locked"<<std::endl;
return FALSE;
}
使用LOCK_EX是对文件描述符fd进行加锁,如果成功,返回0,表示该文件还没有被加锁,可以对其进行写操作。如果失败返回-1,表示该文件已经被加锁,正在被使用,故要等到其解锁后才能使用。
LOCK_NB表示非阻塞。加锁后对该文件的具体写操作如下:
if((flock(fd, LOCK_UN ))<0)
{
std::cout<<"Log::unlock the logfile error"<<std::endl;
return FALSE;
}
这是在文件处理完后,对文件进行解锁,解锁后,其他线程就可以对该文件进行访问了。
0 0
- LINUX多线程读写同一个文件 加锁
- LINUX多线程读写同一个文件 加锁
- 多线程读写文件 加锁
- java多线程读写同一个文件的代码
- linux C++多线程操作文件&输出加锁
- 多线程读写 shared_ptr的加锁
- 多线程分别定时读写同一个文件的样例
- LINUX 多线程加锁
- 读写同一个文件出问题
- linux C语言 同一个文件被不同程序读写
- 为什么多线程读写 shared_ptr 要加锁?
- 为什么多线程读写 shared_ptr 要加锁?
- 为什么多线程读写 shared_ptr 要加锁?
- 为什么多线程读写 shared_ptr 要加锁?
- 为什么多线程读写 shared_ptr 要加锁?
- 为什么多线程读写 shared_ptr 要加锁?
- 多线程读写的时候,什么时候需要加锁
- 为什么多线程读写shared_ptr需要加锁
- repo 的用法
- C++对C的加强 总结(2)
- zoj 1081
- 【LeetCode】Binary Tree Postorder Traversal 二叉树后序遍历递归以及非递归算法
- 实现checkbox全选打钩及消除,点击单个checkbox打钩及消除JS代码实现
- LINUX多线程读写同一个文件 加锁
- OSGI(2)框架的组件运行机制
- zookeeper qa
- C++对C的加强 总结(3)
- jquery-validation 使用
- 推荐的75本经典书籍
- 【高手回避】poj3268,一道很水的dijkstra算法题
- jquery-uploadify3.2使用心得
- 优化MyEclipse 8.6.1的启动速度与运行速度