浅谈无缓存io操作和标准io文件操作区别

浅谈无缓存io操作和标准io文件操作区别

ID:18199247

大小:208.50 KB

页数:15页

时间:2018-09-15

浅谈无缓存io操作和标准io文件操作区别_第1页
浅谈无缓存io操作和标准io文件操作区别_第2页
浅谈无缓存io操作和标准io文件操作区别_第3页
浅谈无缓存io操作和标准io文件操作区别_第4页
浅谈无缓存io操作和标准io文件操作区别_第5页
资源描述:

《浅谈无缓存io操作和标准io文件操作区别》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、浅谈无缓存I/O操作和标准I/O文件操作区别 (2011-05-0211:47:57)分类: linux学习      首先,先稍微了解系统调用的概念:       系统调用,英文名systemcall,每个操作系统都在内核里有一些内建的函数库,这些函数可以用来完成一些系统系统调用把应用程序的请求传给内核,调用相应的的内核函数完成所需的处理,将处理结果返回给应用程序,如果没有系统调用和内核函数,用户将不能编写大型应用程序,及别的功能,这些函数集合起来就叫做程序接口或应用编程接口(ApplicationProgrammingInterface,API),我们要在

2、这个系统上编写各种应用程序,就是通过这个API接口来调用系统内核里面的函数。如果没有系统调用,那么应用程序就失去内核的支持。     现在,再聊不带缓存的I/O操作:     linix对IO文件的操作分为不带缓存的IO操作和标准IO操作(即带缓存),刚开始,要明确以下几点:     1:不带缓存,不是直接对磁盘文件进行读取操作,像read()和write()函数,它们都属于系统调用,只不过在用户层没有缓存,所以叫做无缓存IO,但对于内核来说,还是进行了缓存,只是用户层看不到罢了。如果这一点看不懂,请看第二点;    2:带不带缓存是相对来说的,如果你要写入数

3、据到文件上时(就是写入磁盘上),内核先将数据写入到内核中所设的缓冲储存器,假如这个缓冲储存器的长度是100个字节,你调用系统函:ssize_twrite(intfd,constvoid*buf,size_tcount);写操作时,设每次写入长度count=10个字节,那么你几要调用10次这个函数才能把这个缓冲区写满,此时数据还是在缓冲区,并没有写入到磁盘,缓冲区满时才进行实际上的IO操作,把数据写入到磁盘上,所以上面说的“不带缓存不是就没有缓存直写进磁盘”就是这个意思。     那么,既然不带缓存的操作实际在内核是有缓存器的,那带缓存的IO操作又是怎么回事呢?

4、      带缓存IO也叫标准IO,符合ANSIC的标准IO处理,不依赖系统内核,所以移植性强,我们使用标准IO操作很多时候是为了减少对read()和write()的系统调用次数,带缓存IO其实就是在用户层再建立一个缓存区,这个缓存区的分配和优化长度等细节都是标准IO库代你处理好了,不用去操心,还是用上面那个例子说明这个操作过程:     上面说要写数据到文件上,内核缓存(注意这个不是用户层缓存区)区长度是100字节,我们调用不带缓存的IO函数write()就要调用10次,这样系统效率低,现在我们在用户层建立另一个缓存区(用户层缓存区或者叫流缓存),假设流缓存

5、的长度是50字节,我们用标准C库函数的fwrite()将数据写入到这个流缓存区里面,流缓存区满50字节后在进入内核缓存区,此时再调用系统函数write()将数据写入到文件(实质是磁盘)上,看到这里,你用该明白一点,标准IO操作fwrite()最后还是要掉用无缓存IO操作write,这里进行了两次调用fwrite()写100字节也就是进行两次系统调用write()。    如果看到这里还没有一点眉目的话,那就比较麻烦了,希望下面两条总结能够帮上忙:    无缓存IO操作数据流向路径:数据——内核缓存区——磁盘    标准IO操作数据流向路径:数据——流缓存区——

6、内核缓存区——磁盘    下面是一个网友的见解,以供参考:不带缓存的I/O对文件描述符操作,下面带缓存的I/O是针对流的。    标准I/O库就是带缓存的I/O,它由ANSIC标准说明。当然,标准I/O最终都会调用上面的I/O例程。标准I/O库代替用户处理很多细节,比如缓存分配、以优化长度执行I/O等。    标准I/O提供缓存的目的就是减少调用read和write的次数,它对每个I/O流自动进行缓存管理(标准I/O函数通常调用malloc来分配缓存)。它提供了三种类型的缓存:    1)全缓存。当填满标准I/O缓存后才执行I/O操作。磁盘上的文件通常是全缓存

7、的。    2)行缓存。当输入输出遇到新行符或缓存满时,才由标准I/O库执行实际I/O操作。stdin、stdout通常是行缓存的。    3)无缓存。相当于read、write了。stderr通常是无缓存的,因为它必须尽快输出。    一般而言,由系统选择缓存的长度,并自动分配。标准I/O库在关闭流的时候自动释放缓存。    在标准I/O库中,一个效率不高的不足之处是需要复制的数据量。当使用每次一行函数fgets和fputs时,通常需要复制两次数据:一次是在内核和标准I/O缓存之间(当调用read和write时),第二次是在标准I/O缓存(通常系统分配和管理

8、)和用户程序中的行缓存(fgets的参

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。