是否有可能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文件描述符设置到控制台. (编辑:安卓应用网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
- linux – 自旋锁真的需要DMB吗?
- linux – SQL Plus命令行:箭头键不返回以前的命令
- linux – 如何在tar存档中的文件中grep for pattern而不填满
- linux – 如何确定glibc(glibcxx)二进制版的版本将取决于?
- LINUX实战:Ubuntu下用QEMU搭建ARM Linux运行环境
- Linux内核:内核版本字符串附加”“或”-dirty“
- 默认情况下关闭Linux OOM杀手?
- linux – 使用perl读取系统文件,而不在打开时发出额外的搜索
- linux – 错误:RPC失败; result = 6,HTTP代码= 0
- linux – 如何在ZFS scrub *完成后运行命令*?
