关于linux重定向的解析
apue书中 p64程序清单3.4有4种调用方式及结果
---------------------------------------------
./a.out 0 < /dev/tty
read only
./a.out 1 > temp.foo
write only
./a.out 2 2>>temp.foo
write only, append
./a.out 5 5<>temp.foo
read write
----------------------------------------------
前2个很好解释 大家都能看懂 关键是后面2个 把我害苦了
在网上搜索资料<<linux shell 中"2>&1"含义>>这个看后,终于让我想通了为什么
---------------------------------------------------------------------------
现解释如下:
1) 标准输入0作为参数传递给a.out,
< /dev/tty 这个虚拟tty文件的输入被重定向到了a.out的标准输入
也就是a.out的标准输入就变成了/dev/tty
其实可以写成 ./a.out 0 0</dev/tty
2)第二个同理
可以写成 ./a.out 1 1>temp.foo
所以标准输出绑定到了文件temp.foo
相当于在文件描述符1上打开了temp.foo且是只读的模式
向标准输出写东西就写到了文件temp.foo
3) 第三个同理
在文件描述符2上打开了文件temp.foo 而2是标准出错,用了>>表示以追加的模式打开了文件temp.foo
所以取2的属性就取的是打开文件temp.foo的属性,而这个时候系统已经把文件的状态改了打开且追加的模式
4)同理
在5上以读写模式打开文件,so取文件描述5的属性就是取文件的属性,那么read and write 就可以理解了
-------------------------------------------------------------
取了部分代码放下面:
apue书中 p64程序清单3.4有4种调用方式及结果
---------------------------------------------
./a.out 0 < /dev/tty
read only
./a.out 1 > temp.foo
write only
./a.out 2 2>>temp.foo
write only, append
./a.out 5 5<>temp.foo
read write
----------------------------------------------
前2个很好解释 大家都能看懂 关键是后面2个 把我害苦了
在网上搜索资料<<linux shell 中"2>&1"含义>>这个看后,终于让我想通了为什么
---------------------------------------------------------------------------
现解释如下:
1) 标准输入0作为参数传递给a.out,
< /dev/tty 这个虚拟tty文件的输入被重定向到了a.out的标准输入
也就是a.out的标准输入就变成了/dev/tty
其实可以写成 ./a.out 0 0</dev/tty
2)第二个同理
可以写成 ./a.out 1 1>temp.foo
所以标准输出绑定到了文件temp.foo
相当于在文件描述符1上打开了temp.foo且是只读的模式
向标准输出写东西就写到了文件temp.foo
3) 第三个同理
在文件描述符2上打开了文件temp.foo 而2是标准出错,用了>>表示以追加的模式打开了文件temp.foo
所以取2的属性就取的是打开文件temp.foo的属性,而这个时候系统已经把文件的状态改了打开且追加的模式
4)同理
在5上以读写模式打开文件,so取文件描述5的属性就是取文件的属性,那么read and write 就可以理解了
-------------------------------------------------------------
取了部分代码放下面:
#include "apue.h"
2 #include <stdio.h>
3 #include <fcntl.h>
4 int main(int argc, char * argv[])
5 {
6 int i = 0;
7 int val;
8 for(; i < argc; i++)
9 {
10 printf("%s\n", argv[i]);
11
12 }
13 val = fcntl(atoi(argv[1]), F_GETFL, 0);
14 if (val < 0)
15 err_sys("fcntl error");
16 switch (val & O_ACCMODE)
17 {
18 case O_RDWR:
19 printf("read write\n");
20 break;
21
22 }
23 if (val & O_APPEND)
24 printf(",append\n");
25 // printf("O_RDONLY %d\n", O_RDONLY);
26 //printf("O_RDWR %d\n", O_RDWR);
27 //printf("O_APPEND %d\n", O_APPEND);
28 return 0;
29 }