磁盘操作都是基于块进行的,所以请求以块大小的整数倍对齐地址时,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);
![这里写图片描述](https://img-blog.csdn.net/20170902151309318?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvbm9fd2E=/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)
fdopen()
#include <stdio.h>
FILE *fdopen(int fd, const char *mode);
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);