一个缓冲区不需要很大,它被设计成为环形的数据结构,以便管道可以被循环利用。当管道中没有信息的话,从管道中读取的进程会等待,直到另一端的进程放入信息。...: 没有缓冲区,数据会立即读入或者输出到外存文件和设备上(标准错误
因为python是默认采用带缓冲的fputs, 又因为标准输出被改写到管道, 所以将会采取全缓冲的方式(shell 命令具体要看实现,...因为有些是用不带缓冲write实现,如果不带缓冲区,会直接写入管道), 所以将会采取全缓冲的方式, 也就是说, 直到缓冲区被填满, 或者手动显示调用flush刷入,才能看到输出。...然而管道也是有大小的~ 具体可以去看posix标准, 所以我们得出结论是: 只要COMMAND1的输出写入管道的写端(不管是缓冲区满还是手动flush), COMMAND2都将立刻得到数据并且马上处理。...6.当要写入的数据量大于PIPE_BUF时,linux将不再保证写入的原子性。