三、缓冲输入输出

磁盘操作都是基于块进行的,所以请求以块大小的整数倍对齐地址时,I/O效率是最理想的。
操作系统效率随系统调用次数的增多而急剧下降。例如每次读1个字节读1024次明显比一次读1024字节慢。如果每次不是块的整数倍效率也不是最理想的。

用户-缓冲I/O

轻量级I/O请求通常使用用户缓冲I/O,它是在用户空间而不是内核完成的。
块大小:通常是512字节、1024字节等。所以大规模操作的时候我们需要设置为块的整数倍或约数。这是因为内核和硬件之间是通过块交互,使用块值能保证块对齐。我们可以通过stat()或stat(1)指定设备块大小。
当用户写入数据会被存储在用户缓冲区,当用户缓冲区达到一个给定值的时候就会被写出。所以看缓冲区大小是块给出。

标准I/O

stdio不多说了。

fopen()打开文件

#include <stdio.h>

FILE *fopen(const char *path, const char *mode);    //可打开一个path文件设置它的模式返回一个文件指针。

这里写图片描述

fdopen()

#include <stdio.h>

FILE *fdopen(int fd, const char *mode); //将一个打开的文件描述符转换成一个流,可能的模式和fopen()一样而且必须和原来打开的文件描述符的模式匹配,关闭流也会关闭对应的文件描述符
FILE *stream;
int fd;
fd = open("home/codefunny/hello.c", O_RDONLY);
if(fd == -1)
    perror("open");
else
{
    stream = fdopen(fd, "r");
    if(!stream)
        /* error */
}

fclose()关闭流

#include <stdi.h>

int fclose(FILE *stream); //所有被缓冲但是
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值