进一步阅读

进一步阅读

如果我使用:

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) 设备是一种可以作为字节流(如文件)进行访问的设备。字符设备和常规文件之间的唯一相关区别是您始终可以在常规文件中来回移动,而大多数字符设备只是数据通道,您只能按顺序访问它们。

编辑:Shell 是 bash。

答案1

这很简单。

echo您运行的外部命令strace很可能是来自 GNU coreutils 的命令。这是用 C 编程语言编写的,并使用 C 运行时库函数(如putchar()和 )fputs()将其需要写入程序的标准输出。

在C语言中,输出到标准输出可以是全缓冲,行缓冲, 或者无缓冲的。发生的情况的规则实际上是 C 语言规范的一部分,适用于跨操作系统,并且以标准输出是否“可以确定不引用交互设备”的抽象术语编写。

在 Unix 和 Linux 操作系统上,它们应用的具体方式是,如果isatty()表明文件描述符不是终端,则标准输出将被完全缓冲。这就是本例中的“交互式设备”。在您的操作系统上,标准输出否则是行缓冲的。 C 语言标准不强制要求后者。这就是 GNU C 库的内容此外除了 C 语言标准所说的之外,还记录了它所做的事情。

因此,当echo命令的标准输出不是终端而是文件时,程序中的 C 库会缓冲所有对标准输出的单独写入,并write()在缓冲区已满或程序完成时进行一次大调用。而当标准输出终端,C 库仅缓冲内容直到输出换行符,此时它write()是缓冲区的内容。

因此观察到的系统调用。

进一步阅读

相关内容