发布网友
共3个回答
懂视网
今天纠结dup的时候,无意间发现,open的返回让我有点不敢相信,百思不得其解。 因为我不敢相信“返回是0”,STDIN_FILENO,STDOUT_FILENO,STDERR_FILENO,分别对应的是0,1,2这三个file descriptor 问题出在下面这行代码上面 if(file_descriptor = open(./te
今天纠结dup的时候,无意间发现,open的返回值让我有点不敢相信,百思不得其解。
因为我不敢相信“返回值是0”,STDIN_FILENO,STDOUT_FILENO,STDERR_FILENO,分别对应的是0,1,2这三个file descriptor
问题出在下面这行代码上面
if(file_descriptor = open("./text.t",O_RDWR) < 0) { printf("open error Process end "); return 0; }
我一直觉得open的返回值最小是3,但是自己写的代码出来的结果却是0,纳闷啊。。。
打印的结果是:
file descriptor is 0
dup2 return value:4
dup return value 4
dup2 return value:5
dup return value 5
dup2 return value:6
dup return value 6
教训是没事别少写括号。。。没有必要去纠结这种优先级的问题,保持良好的习惯,写括号,OK
if((file_descriptor = open("./text.t",O_RDWR)) < 0) { printf("open error Process end "); return 0; }这样就OK了
file descriptor is 3
dup2 return value:4
dup return value 4
dup2 return value:5
dup return value 5
dup2 return value:6
dup return value 6
经过这次小纠结,有一点共识得到强化,open的返回值不可能是0,1,2,这三个file descriptor是一直被打开的(除非在某个进程内被暂时关闭)。
热心网友
open的返回值不是设备号,每次调用open函数都会返回一个不相同整数。 该整数其实是系统用来关联是那次调用打开的。追问噢,但为什么我每次运行应用程序都是返回3呢?我打开其他设备文件也是返回3。
追答这个数字是可以反复使用的,你的程序关闭了自然就返还给操作系统了。下次打开时,有可能与上次打开的是一样的数字。如果不关闭,同时又打开一次(即:连续open两次),则这次的数字就不一样了。
热心网友
那东西是句柄吧……