看似不起眼的日复一日,会在将来的某一天,突然让你看到坚持的意义。
缓存类型
缓存类型:全缓存 行缓存 不缓存
全缓存: fopen打开文件时默认是全缓存,我们打开的普通文件也是
读:当 缓存区为空 时才进行实际的read操作,否则,每次从缓存区读取数据
写:当缓存区满 时才进行实际的write操作,否则,每次写入的内容是写到缓存区的,可以使用
fflush() 强制刷新缓存区。
行缓存: printf默认操作的是stdout,stdout默认是行缓存。当流遇到一个终端时,典型的行缓存。
当遇到下面四种情况都会从缓存中输出内容。
当遇到\n
执行fflush(stdout)
程序结束
行缓存满
通常与终端相关的文件都是行缓存,例如:stdin stdout
无缓存: stderr
标准I/O库不对字符进行缓冲,例如stderr。
很多的人机交互界面要求不可全缓存。
标准出错决不会是全缓存的。
在任何时刻,可以使用fflush强制刷新一个数据流。
fflush()函数、_exit()函数
fflush();//强制刷新缓冲区。
使用的头文件: #include <stdio.h>
函数定义:int fflush(FILE *stream);
返回值:成功返回0,否则返回EOF,且将errno设为指示er-ror.
fflush(stdout);//强制刷新缓冲区,将缓冲区内的数据输出到设备。
exit(0) 表示程序正常退出
exit⑴/exit(-1)表示程序异常退出。
_exit()不执行I/O缓存的刷新动作,直接使进程终止运行,清除其使用的内存空间,并销毁其在内核中的各种数据结构。main 函数中使用 return 后返回,return 执行后把控制权交给调用函数,结束该进程。
具体我们来看一下案例:
#include <stdio.h>
#include<unistd.h>
int main(int argc, char *argv[])
{
printf("hello world");//stdout是行缓存
sleep(5);
printf("hello");
return 0;
}
结果是5秒后要printf输出的全部打印即hello worldhello。
ubuntu@ubuntu-virtual-machine:~/IO$ ./a.out
hello worldhelloubuntu@ubuntu-virtual-machine:~/IO$
当我们把return 0;换成_exit(0)后什么也没有打印。 也就是_exit()不执行I/O缓存的刷新动作,直接使进程终止运行,清除其使用的内存空间。
return(); 是某个函数的结束,并返回结果。
exit(); 是整个程序的结束。
把return改成_exit(0)后的结果:
ubuntu@ubuntu-virtual-machine:~/IO$ gcc fflush.c
ubuntu@ubuntu-virtual-machine:~/IO$ ./a.out
ubuntu@ubuntu-virtual-machine:~/IO$
这里我们加入fflush()函数,强制刷新行缓存,
#include <stdio.h>
#include<unistd.h>
int main(int argc, char *argv[])
{
printf("hello world");//stdout是行缓存
fflush(stdout);//强制刷新缓冲区,将缓冲区内的数据输出到设备。
sleep(5);
printf("hello");
_exit(0);//exit(0) 是退出整个进程,不论在哪里调用,都会退出当前进程。
// return 0;
}
结果为先打印hello world,五秒过后程序结束,因为_exit()函数直接退出进程,同时也不会刷新行缓存,也没有’\n’上面我们已经提过遇到那些才会输出打印了,这里不多说,所以不会输出hello。如果这里我们用的是return 0;程序还是会把hello 输出的。
ubuntu@ubuntu-virtual-machine:~/IO$ ./a.out
hello worldubuntu@ubuntu-virtual-machine:~/IO$
注:自己学习记录使用,及理解。如有错误之处望大家指出,谢谢