shell上:
0表示标准输入,从终端输入数据,一般指键盘
1表示标准输出,数据显示到终端,一般指屏幕
2表示标准错误输出,错误提示显示到终端,一般指屏幕
> 默认为标准输出重定向,与 1> 相同
第二条命令:cat > test.txt << EOF, 先将cat的输出重定向到文件test.txt,再将输入重定向到命令行端以EOF为结束标记间的内容。等价于cat 1>test.txt 0<< EOF 和cat 0<<EOF 1>test.txt
grep da * > greplog1
grep da * > greplog2 1>&2
grep da * > greplog3 2>&1 //grep da * 2>greplog4 1>&2 结果一样
#查看greplog1会发现里面只有正常输出内容
#查看greplog2会发现里面什么都没有
0表示标准输入,从终端输入数据,一般指键盘
1表示标准输出,数据显示到终端,一般指屏幕
2表示标准错误输出,错误提示显示到终端,一般指屏幕
> 默认为标准输出重定向,与 1> 相同
2>&1 意思是把 标准错误输出 重定向到 标准输出.
2>1表示把标准错误重定向到文件1中去,用&区分数字表示的是文件名还是文件描述符
&>file 意思是把 标准输出 和 标准错误输出 都重定向到文件file中
<,<< ,>,>>区别
""<"表示输入重定向运算符,">"表示输出重定向t运算符。
"<<"这种输入告诉Shell,当前标准输入来自命令行的开始标记 tag 和结束标记 tag 之间的内容作为输入。
">"输出时,如果文件不存在会自动建立一个文件,如果第二次输入时,会覆盖前一次的输入内容。
">>"表示把第二次的输出内容追加到文件中去,而不是覆盖。
ps ef > a.txt 把ps命令的执行结果重定向到a.txt文件中,而不在屏幕上显示了。
wc<a.txt wc原本直接统计从终端输入的文本行信息(行数,单词数,字符数),这里将输入重定向为a.txt文件
例子1 <<:
pp@pp-Satellite-L700~$ cat << EOF
> hello
> what?
> ok
> bye
> EOF
hello
what?
ok
bye
pp@pp-Satellite-L700$ cat >test.txt << EOF
> hello
> what?
> ok
> bye
> EOF
pp@pp-Satellite-L700$ cat test.txt
hello
what?
ok
bye
第一条命令:cat <<EOF, 表示以EOF为结束标识,在这之间的内容全部作为输入传送给cat
第二条命令:cat > test.txt << EOF, 先将cat的输出重定向到文件test.txt,再将输入重定向到命令行端以EOF为结束标记间的内容。等价于cat 1>test.txt 0<< EOF 和cat 0<<EOF 1>test.txt
例子2:
grep da * > greplog1
grep da * > greplog2 1>&2
grep da * > greplog3 2>&1
#查看greplog1会发现里面只有正常输出内容
#查看greplog2会发现里面什么都没有
#查看greplog3会发现里面既有正常输出内容又有错误输出内容
例子3:
ls 1>/dev/null 2>/dev/null
/dev/null是一个特殊文件设备,所有的输入都将会被抛弃掉。常用来过滤掉不想看到的输出。
参考:
http://blog.sina.com.cn/s/blog_406127500102uxrs.html
http://blog.csdn.net/jfkidear/article/details/7823486