user56834 Asked: 2021-10-26 02:57:41 +0800 CST2021-10-26 02:57:41 +0800 CST 2021-10-26 02:57:41 +0800 CST Linux/Unix 中是否有“非标准”流? 772 Linux中所谓的“标准流”就是stdin、stdout、stderr。但它们必须被称为“标准”是有原因的。有非标准流吗?内核是否从根本上区别对待这些非标准流? file-descriptors open-files 2 个回答 Voted Best Answer Gilles 'SO- stop being evil' 2021-10-26T03:11:50+08:002021-10-26T03:11:50+08:00 在这种情况下,“流”是进程中打开的文件。(“流”这个词可以有其他的意思,在这里是题外话。) 三个标准流是应该在程序启动时已经打开的流。文件描述符 0 被称为标准输入,因为这是程序应该读取用户输入或其默认数据输入的地方。文件描述符 1 被称为标准输出,因为这是程序应该写入其正常数据输出的地方。文件描述符 2 被称为标准错误,因为这是程序应该写入其错误消息的地方。 其他文件描述符编号不是标准的,因为它们没有预先分配的角色。它们最终会被用于程序想要的任何东西。因此可以将程序打开的任何文件称为“非标准流”,但这会很奇怪和令人困惑:“打开的文件不是标准输入、标准输出或标准错误”实际上不需要名称,而“非标准流”听起来像是某些特殊类型的文件或通过非标准方法打开的文件,情况并非如此。 文件描述符 0-2 的常规角色由标准库和某些程序授予。例如,控制台登录程序和终端仿真器启动 shell(或其他程序),终端在这些文件描述符上打开。C 标准库FILE*为这三个标准描述符创建对象(C 称为流)。内核中没有特殊处理。 Frédéric Loyer 2021-10-26T03:18:11+08:002021-10-26T03:18:11+08:00 内核以相同的方式处理所有文件描述符。让进程使用 0 作为输入 (stdin)、1 作为输出 (stdout) 并在 2 (stderr) 上打印错误只是一个惯例。 当您的终端启动时,它会创建一个伪 tty,并将启动一个带有 0、1、2 个文件描述符的输入/输出的 shell。然后,如果您的程序不使用此约定,则必须适当地重定向输入或输出。
在这种情况下,“流”是进程中打开的文件。(“流”这个词可以有其他的意思,在这里是题外话。)
三个标准流是应该在程序启动时已经打开的流。文件描述符 0 被称为标准输入,因为这是程序应该读取用户输入或其默认数据输入的地方。文件描述符 1 被称为标准输出,因为这是程序应该写入其正常数据输出的地方。文件描述符 2 被称为标准错误,因为这是程序应该写入其错误消息的地方。
其他文件描述符编号不是标准的,因为它们没有预先分配的角色。它们最终会被用于程序想要的任何东西。因此可以将程序打开的任何文件称为“非标准流”,但这会很奇怪和令人困惑:“打开的文件不是标准输入、标准输出或标准错误”实际上不需要名称,而“非标准流”听起来像是某些特殊类型的文件或通过非标准方法打开的文件,情况并非如此。
文件描述符 0-2 的常规角色由标准库和某些程序授予。例如,控制台登录程序和终端仿真器启动 shell(或其他程序),终端在这些文件描述符上打开。C 标准库
FILE*
为这三个标准描述符创建对象(C 称为流)。内核中没有特殊处理。内核以相同的方式处理所有文件描述符。让进程使用 0 作为输入 (stdin)、1 作为输出 (stdout) 并在 2 (stderr) 上打印错误只是一个惯例。
当您的终端启动时,它会创建一个伪 tty,并将启动一个带有 0、1、2 个文件描述符的输入/输出的 shell。然后,如果您的程序不使用此约定,则必须适当地重定向输入或输出。