微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

是否有可能linux文件描述符0 1 2不适用于stdin,stdout和stderr?

程序开始时,认情况下是否需要stdin,stdout和stderr的文件描述符0,1和2? API调用(例如open(…),socket(…))是否会返回0,1和2,因为这些值已经被采用了?是否存在open(…)或socket(…)返回0,1或2的情况.0,1和2与stdin,stdout和stderr无关.

解决方法

file descriptor级别,stdin被定义为文件描述符0,stdout被定义为文件描述符1;和stderr被定义为文件描述符2.见 this.

即使您的程序 – 或shell-更改(例如,使用dup2(2)重定向)什么是文件描述符0,它始终保持stdin(因为根据定义STDIN_FILENO为0).

因此,stdin当然可以是管道或套接字或文件(​​不是终端).如果是tty,您可以使用isatty(3)进行测试,和/或使用fstat(2)获取状态信息.

open(2)pipe(2)socket(2)这样的系统调用可以提供例如STDIN_FILENO(即0)如果该文件描述符是空闲的(例如因为之前已经是close(2)-d).但是当发生这种情况时,它仍然是stdin的定义.

当然,在stdio(3),FILE流stdin有点复杂.你的程序可以是fclose(3),freopen(3),fdopen(3) ……

当魔术启动/ sbin / init作为第一个进程时,内核可能会将stdin,stdout和stderr文件描述符设置到控制台.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐