程序开始时,默认情况下是否需要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文件描述符设置到控制台.
总结以上是内存溢出为你收集整理的是否有可能linux文件描述符0 1 2不适用于stdin,stdout和stderr?全部内容,希望文章能够帮你解决是否有可能linux文件描述符0 1 2不适用于stdin,stdout和stderr?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)