pread()与read()的区别
来源:互联网 发布:明朝灭亡的原因 知乎 编辑:程序博客网 时间:2024/05/20 11:46
查看man pread,大多的篇幅都在讲read()的细节,只有最后一段讲到:pread()的行为与read()完全一致,只是pread()不会去修改文件指针,文件指针由外部来指定。
仅仅只是这样吗?TokyoCabinet中讲到,使用pwrite和pread作为高效的系统调用方式,当时我还特地测试了read()和pread()的性能差异,发现两者几乎没有差别。
如今又细细阅读TokyoCabinet的源码,发现tchdbget()函数的实现过程中,加锁和调用顺序是这样的:
tchdbget() ->
HDBLOCKMETHOD(hdb, false) //在方法上加读锁
HDBLOCKRECORD(hdb, bidx, false) //在记录上加读锁
tchdbgetimpl() -> //读取的实现函数
tchdbreadrec() -> //读取记录
tchdbseekreadtry() -> pread()
假设同一瞬间两个线程读取相同的记录,则最终在pread()上,同一个fd会被两个线程调用。代码为什么没互斥?这也可以说明,pread()是可以在多线程下使用的。
从参数上看来,read()是肯定不能在多线程下使用的。
仅仅只是这样吗?TokyoCabinet中讲到,使用pwrite和pread作为高效的系统调用方式,当时我还特地测试了read()和pread()的性能差异,发现两者几乎没有差别。
如今又细细阅读TokyoCabinet的源码,发现tchdbget()函数的实现过程中,加锁和调用顺序是这样的:
tchdbget() ->
HDBLOCKMETHOD(hdb, false) //在方法上加读锁
HDBLOCKRECORD(hdb, bidx, false) //在记录上加读锁
tchdbgetimpl() -> //读取的实现函数
tchdbreadrec() -> //读取记录
tchdbseekreadtry() -> pread()
假设同一瞬间两个线程读取相同的记录,则最终在pread()上,同一个fd会被两个线程调用。代码为什么没互斥?这也可以说明,pread()是可以在多线程下使用的。
从参数上看来,read()是肯定不能在多线程下使用的。
- pread()与read()的区别
- pread,pwrite,read,write区别
- pread,pwrite,read,write区别
- Linux系统函数read()/write()/pread()/pwrite()的区别
- Linux系统函数read()/write()/pread()/pwrite()的区别
- read()/write()/pread()/pwrite()等等
- read()/write()/pread()/pwrite()等等
- fread与read的区别
- recv与read的区别
- fread与read的区别
- read与fread的区别
- pread与pwrite
- windows下的ReadFile与Linux下的pread
- 嵌入式 read、pread、write、pwrite等等
- Read Committed与Read committed snapshot的区别以及Read Committed Snapshot与Sanpshot的区别
- read 与 fread 的区别的误解
- read 与 fread 的区别的误解
- read 与 fread 的区别的误解
- 小妹上班去了
- IE6 屏蔽JS错误提示
- ATL thunk机制
- 201202
- 跑马灯效果
- pread()与read()的区别
- Java 网址推荐(含Html5)
- adb 控制应用程序安装在内存还是SD卡 解决INSTALL_FAILED_MEDIA_UNAVAILABLE问题
- base-kernel-内嵌汇编
- GestureDetector的用法和介绍
- Java NIO API详解
- 如何把自己的驱动编译进内核或模块
- 回老家发展VS在北京发展—一个北漂族的心声
- NSIS安装制作程序