系统编程之文件IO(八)——缓冲区的设置

一、缓冲类型

1.1 全缓冲

缓冲方式要求填满整个缓冲区后才进行1/O系统调用操作

第一次执行I/O操作时,ANSI标准的文件管理函数通过调用malloc函数获得需要使用的缓冲区,默认大小为8192
位置:/usr/include/stdio.h——#define _G_BUFSIZ 8192

1.2 行缓冲

当在输入和输出中遇到换行符时,标准I/O库函数将会执行系统调用操作
当所操作的流涉及一一个终端时(例如标准输入和标准输出),使用行缓冲方式
默认行缓冲区的大小为1024

1.3 无缓冲

标准I/O库不对字符进行缓存,直接调用系统调用
标准出错流stderr通常是不带缓冲区的,这使得出错信息能够尽快地显示出来。

二、清除和设置文件缓冲区

2.1 设置缓冲区函数

  • setbuf、setvbuf两个函数将使得打开文件后,用户可建立自己的文件缓冲区,而不使用fopen()函数打开文件设定的默认缓冲区。
  • void setbuf(FILE *stream,char *buf);
    buf指出的缓冲区长度由头文件stdio.h中定义的宏BUFSIZE的值决定
    当选定buf为空时,setbuf函 数将使的文件I/O不带缓冲
  • void setvbuf(FILE *stream,char *buf,int type,unsigned size);(经常)
    由malloc函数来分配缓冲区。参数size指明了缓冲区的长度(必须大于0),而参数type则表示了缓冲的类型,
    _IONBF:不缓冲
    _IOLBF:行缓冲
    _IOFBF:全缓冲
void main()
{
	//setbuf(stdout, NULL);//取消缓冲区
	stdvbuf(stdout, NULL, _IONBF, 0);
	printf("hello\n");
	while(1);
	//可以输出hello
}
void main()
{
	char *buf = (char *)malloc(sizeof(char) * 20)
	//setbuf(stdout, NULL);//取消缓冲区
	stdvbuf(stdout, buf, _IONBF, 20);
	printf("hello world");
	while(1);
	//可以输出hello world
}

原因:缓冲区不止有hello world,可能还有一些系统自加上去的,所以可以输出,50也可以,但是如果是200,就输出不了,一般是100起步

注意:fread是无缓冲的,所以效率会更高

fwrite有缓冲

2.2 清除文件缓冲区函数

  • int fflush(FILE *stream);
    清除由strem指向的文件缓冲区里的内容。常用于写完些数据后,立即用该函数清除缓冲区,以免误操作时,破坏原来的数据
    int flushall; 清除所有打开文件所对应的文件缓冲区。

三、应用场景(优化读写效率,适当调整缓冲区的大小)

如何提高文件的读写效率?
可以对缓冲区进行操作
改成无缓冲,用开销换时间,增大CPU开销,实现文件读写效率
增大缓冲区是减小开销,有可能,浪费
小文件不需要更改,超过几百兆,需要看是缓冲区的

内存的读写速度是远远大于磁盘的读写速度的

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
好的,我可以为你介绍一下如何使用 Java 编写程序实现文件拷贝。 Java 提供了非常方便的 I/O 类来处理文件读写操作。文件拷贝的基本思路是读取源文件中的数据,然后将数据写入到目标文件中。下面是一个简单的文件拷贝程序示例: ```java import java.io.*; public class FileCopy { public static void main(String[] args) throws IOException { // 源文件路径 String srcFilePath = "C:/temp/source.txt"; // 目标文件路径 String destFilePath = "C:/temp/dest.txt"; // 创建输入流和输出流 FileInputStream fis = new FileInputStream(srcFilePath); FileOutputStream fos = new FileOutputStream(destFilePath); // 定义缓冲区,每次读取 1024 个字节 byte[] buffer = new byte[1024]; int len; // 循环读取源文件中的数据,并将数据写入到目标文件中 while ((len = fis.read(buffer)) != -1) { fos.write(buffer, 0, len); } // 关闭输入流和输出流 fis.close(); fos.close(); System.out.println("文件拷贝完成!"); } } ``` 在上面的示例中,我们首先定义了源文件路径和目标文件路径。然后创建了输入流和输出流,用于读取源文件和向目标文件写入数据。我们定义了一个缓冲区,每次从输入流中读取 1024 个字节,并将这些字节写入到输出流中。最后,我们关闭输入流和输出流,并输出一条完成信息。 需要注意的是,上面的代码中使用了 try-catch 语句来捕获可能出现的 IOException 异常。这是因为在文件读写过程中可能会出现异常,比如文件不存在、文件无法读取等等。为了保证程序的健壮性,我们需要使用 try-catch 语句来处理这些异常。 希望这个简单的示例可以帮助你了解如何使用 Java 编写文件拷贝程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

周末不下雨

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值