数组缓存区
⑴ 缓冲区是什么意思
缓冲区,也称为缓存,是内存空间的一部分。也就是说,在内存空间中预留了一定的存储空间,用来缓冲输入或输出的数据。这个保留的空间称为缓冲区。
缓冲区是固定数据量的容器,它的功能是一个内存或一个分段的传输区,数据可以存储在这里,以后用于检索。
缓冲的四个性质
1.容量(容量)
指缓冲区可以容纳的数据元素的最大数量。该容量是在创建缓冲区时设置的,不能更改。
2、上限(极限)
引用缓冲区中不能读写的第一个元素数组的下标索引。它也可以被认为是缓冲区中元素的实际数量。
3.位置
指的是要读取或写入的下一个元素的索引。该值将随着get()或put()的调用而自动更新。
4.马克(马克)
指备忘录位置。调用mark()设置mark = position,调用reset()设置position = mark。标记在设置之前是未定义的。
⑵ C语言缓冲区的问题:下面是代码
输出缓冲区:
c标准规定fflush()函数实现,用来刷新输出(stdout)缓存的,对于(stdin)是么有意义的,gcc也不能使用fflush(stdin)来刷新,因为gcc么实现它。
那么为什么要刷新呢,个人认为是这样的
打个比方getchar()函数,我们知道他是从界面读取用户输入的字符,读取之后编译器就把它放在缓存中,当达到一定值的时候,才写入文件什么的,或者我们自己主动调用函数写进去,这个时候如果你还要读取字符到另一个文件中,你会发现这个时候不是你要写入文件的字符,这个时候你就应该刷新下缓存。
打个比较典型的比方:
char
p[]={“a”,“b”,“c”};
printf("%d",strlen(p));
我们发现输出的数值不是我们想象的3,为什么,这就是缓存的问题,因为数组p的结束符不是‘/0’,系统会从缓存里面一直读,根据我的理解如果先刷新下缓存,应该就是3了
对于lz的例子我觉得好像么什么问题,如果要加刷新缓冲,那我觉得可能是,你sleep(1)的时候,其他程序开始占用cpu,导致缓存发生变化,导致输出不正常
刷新缓存在tcp和udp通讯的时候用的很多,lz可以看看这方面资料