如果我使用:
strace echo 'a
b
c' > file
底线是:
write(1, "a\nb\nc\nd\n", 8) = 8
但在
strace echo 'a
b
c
d' > /dev/pts/0
这些行是:
write(1, "a\n", 2) = 2
write(1, "b\n", 2) = 2
write(1, "c\n", 2) = 2
write(1, "d\n", 2) = 2
在第二种情况下,为什么它是逐行写,而在第一种情况下是一起写。可能是因为终端是字符设备,但我将字符设备定义为:
字符 (char) 设备是可以作为字节流(如文件)访问的设备。 char 设备和常规文件之间的唯一相关区别是您始终可以在常规文件中来回移动,而大多数字符设备只是数据通道,您只能按顺序访问。
编辑:Shell 是 bash。
这很简单。
echo
您运行的外部命令strace
很可能来自 GNU coreutils。这是用 C 编程语言编写的,并使用 C 运行时库函数如putchar()
和fputs()
来编写它需要写入程序的标准输出的内容。在 C 语言中,标准输出的输出可以是完全缓冲的、行缓冲的或无缓冲的。发生情况的规则实际上是 C 语言规范的一部分,适用于跨操作系统,并以抽象术语编写,即标准输出是否“可以确定不引用交互式设备”。
在 Unix 和 Linux 操作系统上,它们应用的具体方式是,如果
isatty()
函数说文件描述符不是终端,则标准输出是完全缓冲的。在这种情况下,这就是“交互式设备”。在您的操作系统上,标准输出是行缓冲的。C 语言标准不要求后者。这是 GNU C 库在 C 语言标准规定的基础上额外记录的内容。因此,当您的
echo
命令的标准输出不是终端而是文件时,程序中的 C 库会缓冲所有对标准输出的单独写入,并write()
在缓冲区已满或程序完成时进行一次大调用。而当标准输出是终端时,C 库只缓冲内容,直到输出换行符,此时它write()
就是缓冲区的内容。因此观察到的系统调用。
进一步阅读