当前位置:  技术问答>linux和unix

Linux下多线程写入同一个文件

    来源: 互联网  发布时间:2016-11-07

    本文导语:  用Linux底层文件API操作(不带buffer) 其实就是自己写个简单的数据库,把数据库保存在文件中。 为了提高写入性能,考虑用多线程,请有经验的大虾指点指点! 参考文章: (呵,权当收藏) 如何实现多进程写一个...

用Linux底层文件API操作(不带buffer)

其实就是自己写个简单的数据库,把数据库保存在文件中。
为了提高写入性能,考虑用多线程,请有经验的大虾指点指点!

参考文章:
(呵,权当收藏)
如何实现多进程写一个文件
http://student.csdn.net/space.php?uid=45153&do=blog&id=38908
多线程同步写入同一个文件的问题
http://linux.chinaunix.net/bbs/viewthread.php?tid=1022320
多线程写同一个文件
http://www.oschina.net/bbs/thread/14537?p=1
linux多线程设计
http://baike.baidu.com/view/400319.htm

现在还没动手,还在思考阶段:
1.看上去在写入的时候一定要加锁,因为设计记录是定长的,如果指定线程从文件指定位置开始写入是不是可以不用加锁了?
2.如果加锁,写入速度会不会更慢?因为是数据库日志文件,用了O_DIRECT参数本来就已经很慢了

|
如果每个线程从不同的起点写入,感觉可以不用加锁
但是读的时候只怕要加锁,否则就是脏读
可以考虑使用读写锁
int pthread_rwlock_rdlock(pthread_rwlock_t *rwlock);
int pthread_rwlock_wrlock(pthread_rwlock_t *rwlock);
int pthread_rwlock_unlock(pthread_rwlock_t *rwlock);

|
加锁肯定会影响效率

|
可以考虑单独一个线程负责写文件,其他线程都是跟这个线程交互数据就行了,只需要很小量的锁

    
 
 

您可能感兴趣的文章:

  • Windows和Linux下C++类成员方法作为线程函数方法介绍
  • 请问Linux核心支持多线程吗?开发库有线程库吗?线程好用吗?(稳定?)
  • Linux下GCC内置原子操作函数(多线程资源访问)介绍
  • 求个linux多线程编程的例子,要有线程池的 通用些更好
  • 请问Linux下线程开销为什么这么大?一个线程要占用近10M内存
  • Linux多线程时一些线程分不到时间片
  • 说说windows线程和linux线程的区别?
  • linux 下多线程 每个线程能否使用alarm来处理,信号是否会乱呢?
  • linux下,如何在多线程中每个线程设置一个定时器,在线等,急。。。谢谢
  • 在创建linux线程时为什么会多一个线程?
  • linux如何主动将线程放入到线程调度队列中重新排队?
  • 在linux RH73下为什么单进程只能开1021个线程线程.
  • Linux下如何让主线程挂起一个指定的时间段而子线程继续运行?谢谢
  • LINUX下有没有线程概念,和WIN下线程概念有什么不同,谢谢.
  • linux线程编程问题
  • linux线程最大数,奇怪,怎么只有300?而且线程是用完就没了,不是同时300啊!
  • 跪求:linux下pthread 双线程计算和单线程的运行时间完全相同是为什么?
  • linux线程与进程的问题
  • linux 下子线程不能执行的问题?
  • linux多线程编程的问题
  • linux多线程编程
  • 故障求助:linux系统无法向磁盘写入文件
  • 如何在Windows下向Linux分区写入文件?
  • linux下,如何向文件中写入文件结束符。
  • 高分提问:为何在局域网内可以访问linux机器,然而不能在其文件夹内写入文件?
  • linux下文件写入问题。
  • linux下可以访问windows分区,但无法向其写入数据,why?how?
  • 如何在Linux下的Snort中直接写入Windows下的MS-SQL
  • linux svn 下文件被写入了 <<<<<<< .mine 这样的字符,谁知道怎么回事吗?
  • 如何在LINUX下打开一个设备文件,如何向里面写入数据?
  • linux下利用fwrite文件写入过程中突然断电的处理
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Linux_centos_redhat下tar命令解压tgz文件方法
  • 用java读中文linux中的文件是正确的,用java读英文linux版本中的文件是乱码,如何使英文linux读出的文件数据也是中文的?
  • linux下nm命令(显示可执行文件的符号信息)介绍以及常见nm命令用法举例
  • Linux查找包含指定文字的文件(linux查找指定文件)
  • Linux下c函数dlopen实现加载动态库so文件代码举例
  • 请问LINUX内核下,哪些文件夹下的文件是跟LINUX的硬件平台无关的?
  • mount命令(linux操作系统)挂载卸载文件系统(cifs,光驱,nfs等)方法介绍
  • 请问各位linux开发大虾,linux下有类似VC中depends的工具可以查看文件调用了哪些so文件吗?
  • linux内存文件系统ramfs实现原理
  • 急::在Linux下怎么根据另一台windows或linux的文件名,去得到这个文件
  • linux/Centos/ubuntu下如何使用umask命令修改新建文件时的默认权限
  • 我的机器装了WINDOWS2000 和 LINUX 7.3 , 请问在LINUX 中如何访问`WIN2K中的文件?同样在WIN2K中如何访问LINUX 中的文件?
  • Linux内存文件系统(ramdisk)的三种实现方式
  • 请问如何在WINDOWS中访问linux下的文件,并把Windows下的文件复制到linux下的分区中
  • 根据文件大小查找文件的find命令举例(Linux,centos,redhat)
  • linux下copy文件通常又些文件名的大小写会发生变化的,而linux又对大小写敏感,如何解决这一问题
  • Linux下glibc库文件锁:协同锁(advisory lock)和强制锁(mandatory lock)
  • Redhat Linux下用c怎么可以知道一个文件是文件夹还是真的文件?
  • Linux下u盘文件系统相关操作
  • [提问]Linux下如何把多个.a文件编译一个.so文件,或者把多个.so文件编译成一个.so文件
  • linux下find查找文件命令详细介绍及find文件用法举例说明
  • linux中对文件排序的命令(文件夹中包含子文件)
  • linux c/c++ IP字符串转换成可比较大小的数字
  • 在win分区上安装linux和独立分区安装linux有什么区别?可以同时安装吗?(两个linux系统)
  • linux哪个版本好?linux操作系统版本详细介绍及选择方案推荐
  • 在虚拟机上安装的linux上,能像真的linux系统一样开发linux程序么?
  • secureCRT下Linux终端汉字乱码解决方法
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在有linux的盘)
  • 高分提问:为何在局域网内可以访问linux机器,然而不能在其文件夹内写入文件? iis7站长之家
  • 安装vmware软件,不用再安装linux系统,就可以模拟linux系统了,然后可以在其上学习一下LINUX下的基本操作 了?
  • Linux常用命令介绍:更改所属用户群组或档案属性


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3