底层文件I/O操作中read()函数的缓存问题

2018-06-17 20:41:03来源:未知 阅读 ()

新老客户大回馈,云服务器低至5折

  最近在学习Linux过程中看到文件I/O操作这里时,文件I/O操作的系统调用涉及的5个函数:open(),read(),write(),lseek(),close()。在一开始就阐明这些函数的特点是不带缓存,直接对文件进行读写操作。而又在其后说到read()函数用于将从指定文件描述符中读出的数据放到缓存区中,并返回实际读入的字节数。这里与之前说的不带缓存很明显的发生了冲突。

  网上查阅read()函数也几乎没有提到这一问题,最后与fread()带缓存的对比才明白。read()的缓存这一缓存指的是应用程序自己开辟的缓存区,其不带缓存是指没有像fread()那样由操作系统提供缓存空间。总之,fread()的缓存区由操作系统开辟,read()的缓存区由应用程序开辟,至于read()中的buf到底在哪这应该涉及操作系统的知识了,这也是下一步将要学习的部分。

标签:

版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有

上一篇:使用opencv调用24*24点阵字库和8*16ASCII字库在图片显示文字数字

下一篇:(七):C++分布式实时应用框架 2.0