为什么终端要逐行输入?

Prv*_*dav 2 shell devices write

如果我使用:

strace echo 'a
b
c' > file
Run Code Online (Sandbox Code Playgroud)

底线是:

write(1, "a\nb\nc\nd\n", 8)             = 8
Run Code Online (Sandbox Code Playgroud)

但在

strace echo 'a
b
c
d' > /dev/pts/0
Run Code Online (Sandbox Code Playgroud)

这些线路是:

write(1, "a\n", 2)                      = 2
write(1, "b\n", 2)                      = 2
write(1, "c\n", 2)                      = 2
write(1, "d\n", 2)                      = 2
Run Code Online (Sandbox Code Playgroud)

在第二种情况下,为什么它是逐行写的,而在第一种情况下它是一起写的。可能是因为终端是字符设备,但我得到了字符设备的定义:

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

编辑:Shell 是 bash。

Jde*_*eBP 7

这很简单。

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

在 C 语言中,输出到标准输出可以是full bufferedline bufferedunbuffered。发生的事情的规则实际上是 C 语言规范的一部分,适用于跨操作系统,并以标准输出是否“可以确定不涉及交互式设备”的抽象术语编写。

在 Unix 和 Linux 操作系统上,它们应用的具体方式是,如果isatty()函数表示文件描述符不是终端,则标准输出被完全缓冲。在这种情况下,这就是“交互式设备”。标准输出在您的操作系统上以其他方式行缓冲。C 语言标准并没有强制要求后者。这是 GNU C 库在 C 语言标准所说的基础上另外记录的内容。

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

因此观察到的系统调用。

进一步阅读


归档时间:

查看次数:

126 次

最近记录:

6 年,7 月 前