原文:https://lizijie.github.io/
github:https://github.com/lizijie
四个月前碰到一个问题。
为了提高程序IO效率,会对输出流进行缓冲管理,不会立即写到磁盘。但我在帖子里提到了两个疑问:
1. tail
延时5-10秒,才读取到日志
2. 部分log并不是按逻辑顺序输出。比如
LOG("1");
LOGERR("2");
// 在日志文件里,2竟先打印
2
1
最近从《UNIX环境高级编程》第五章-标准IO/库读到了相关内容,认为可以解答以上2个疑问。
以下大部分内容摘自抄原文。
标准I/O提供了以下3种类型的缓冲:
1. 全缓冲。在这种情况下,填满标准I/O缓存后才进行实际I/O操作。对于驻留在磁盘上的文件通常是由标准I/O实施全缓冲的。
缓存区可由标准I/O例程自动地冲洗(例如,当填满一个缓存