免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 10253 | 回复: 17
打印 上一主题 下一主题

mmap效率问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-07-24 20:58 |只看该作者 |倒序浏览
需要读取一个上G的大文件,原来使用的read函数,多个线程读,多个线程写。(每个写线程有自己的缓冲区)
现在想换成mmap,考虑使用的方法是首先mmap映射到内存,然后写线程使用memcpy复制到缓冲区,读线程再去读。
但是考虑到memcpy的效率很低,所以想问问有什么好的解决办法吗?一般mmap后是否调用memcpy?

论坛徽章:
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
2 [报告]
发表于 2010-07-24 21:34 |只看该作者
mmap不能减少读写

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
3 [报告]
发表于 2010-07-24 22:09 |只看该作者
当然要调用 memcpy ,

你可以使用异步I/O,大块读取,大块写入

论坛徽章:
0
4 [报告]
发表于 2010-07-25 12:06 |只看该作者
这样做,程序的执行效率其实会下降。
mmap没有read快。

论坛徽章:
0
5 [报告]
发表于 2010-07-25 12:59 |只看该作者
不是吧,如果read,write多了的话,mmap还是很明显的要快得多的。我上次用read write复制一个文件大概好像是800K多吧。一个字符一个字符地来,要40多秒。后来我用mmap结果2秒左右就好了。

论坛徽章:
0
6 [报告]
发表于 2010-07-25 14:54 |只看该作者
不是吧,如果read,write多了的话,mmap还是很明显的要快得多的。我上次用read write复制一个文件大概好像是 ...
wohenry84 发表于 2010-07-25 12:59


难道用read/write就得“一个字符一个字符”地来?

论坛徽章:
0
7 [报告]
发表于 2010-07-25 20:20 |只看该作者
如果只是读一下或者写一下,那mmap和read/write没有多大的性能差别,但是如果频繁修改一个文件内容,那mmap的效率就高得多了

论坛徽章:
0
8 [报告]
发表于 2010-07-26 01:10 |只看该作者
如果只是读一下或者写一下,那mmap和read/write没有多大的性能差别,但是如果频繁修改一个文件内容,那mmap的 ...
Momoass 发表于 2010-07-25 20:20



操作系统不是傻子,即便你用write人家也会使用page cache的。
用mmap读取文件会比使用read造成过多更多的异常,用mmap取代read/write的性能,就如同把read/write的缓冲区固定成了PAGESIZE一样。

论坛徽章:
0
9 [报告]
发表于 2010-07-26 21:20 |只看该作者
如果文件读写完成后再同步到硬盘,mmap去掉了系统读写的双缓冲和多次硬件IO。

论坛徽章:
0
10 [报告]
发表于 2010-07-27 08:32 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP