免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: upfantasy
打印 上一主题 下一主题

[C++] 多线程如何同时读写同一个文件? [复制链接]

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
21 [报告]
发表于 2013-02-20 11:14 |只看该作者
upfantasy 发表于 2013-02-20 08:30
回复 7# linux_c_py_php

这个你说的不对,你看看迅雷下载,都是并发写的。


迅雷是为了网络并发下载减少下载时间, 人家分content-range下载当然快了, 磁盘那点寻道可以忽略了.

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
22 [报告]
发表于 2013-02-20 11:15 |只看该作者
读写不同区域可以不加锁并发

论坛徽章:
0
23 [报告]
发表于 2013-02-20 16:17 |只看该作者
多线程中分别打开同一个文件?
回复 22# hellioncu


   

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
24 [报告]
发表于 2013-02-20 16:28 |只看该作者
morris2600 发表于 2013-02-20 16:17
多线程中分别打开同一个文件?
回复 22# hellioncu


嗯,或者用pread/pwrite

论坛徽章:
0
25 [报告]
发表于 2013-02-20 17:09 |只看该作者
加个 flock 排它锁就行了,对要写的一段位置加锁,写完成就释放锁就行。

论坛徽章:
0
26 [报告]
发表于 2013-02-20 17:24 |只看该作者
回复 24# hellioncu


我使用_sopen来做了,可以多线程同时读写同一文件,列位,觉得怎么样?


   

论坛徽章:
1
白羊座
日期:2013-09-18 22:02:26
27 [报告]
发表于 2013-02-20 21:55 来自手机 |只看该作者
硬盘的读写速度比网络传输速度大,迅雷不必考虑硬盘读写。

论坛徽章:
7
天蝎座
日期:2013-09-28 10:45:42双子座
日期:2013-10-16 16:27:09射手座
日期:2013-10-23 10:21:32处女座
日期:2014-09-17 16:44:332015年亚洲杯之巴林
日期:2015-04-09 17:28:01冥斗士
日期:2015-11-26 16:19:0015-16赛季CBA联赛之山东
日期:2018-03-02 23:59:31
28 [报告]
发表于 2013-03-21 14:37 |只看该作者
回复 18# upfantasy

迅雷可不可以这样,不并发写?

而是并发下载,存到一个缓冲中。另一个线程不断的扫这个缓冲,发现达到一定的阈值就写磁盘。

oracle可是这么干的。所有对数据库的修改都是放在缓冲中,然后另一个重做日志进程,将缓冲中的脏数据(改动过的)写入重做日志中。同时写进程监视这些脏缓冲,达到阈值就写数据库.
   

论坛徽章:
0
29 [报告]
发表于 2013-03-22 14:46 |只看该作者
回复 28# cxytz01
我可以明确告诉你,迅雷下载是多线程下载,每个线程下载文件的某一块。下载之前在本地生成一个固定大小的稀释文件,下载来的文件块都是并发写到该稀释文件中。这个我已经实现了。


   

论坛徽章:
7
天蝎座
日期:2013-09-28 10:45:42双子座
日期:2013-10-16 16:27:09射手座
日期:2013-10-23 10:21:32处女座
日期:2014-09-17 16:44:332015年亚洲杯之巴林
日期:2015-04-09 17:28:01冥斗士
日期:2015-11-26 16:19:0015-16赛季CBA联赛之山东
日期:2018-03-02 23:59:31
30 [报告]
发表于 2013-03-22 15:40 |只看该作者
{:3_189:}
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP