Linux_重定向_执行细节_一个例子

今天写完shell脚本调试一下,发现一个有意思的事情~实验并记录一下~

重定向,一般用的时候就直接用了,有时候得去考虑执行细节。

例子一、

写法1:

        command 1>output_file 0<input_file 2>error_file

写法2:

        command 2>error_file 1>output_file 0<input_file

考虑一下从左至右的执行,写法1,如果input_file有问题了,报错了,2>error_file还没有被执行到,结果错误信息写入terminal。

例子二、

当前目录下只有一个文件

/home/lijungang/temp
|---t.txt

% ls 1>aaa.log

得到的结果目录

/home/lijungang/temp
|---aaa.log
|---t.txt

你猜一下,aaa.log文件的内容应该是一行:t.txt吧?我也这么认为,可惜错了。

aaa.log
t.txt

仔细想一下执行细节:ls命令去扫描当前目录之前,须先建立aaa.log文件,之后扫描的时候已经多了一个文件aaa.log

为了证明这一点,先把当前目录情况,之后执行 ls 1>aaa.log 再查看aaa.log内容,果然仅仅一行:aaa.log

okay!finish this lesson learn.

==>>不能把输出文件写入执行目录

那如果我非要把输出放入当前目录呢?

方法就是让ls执行完毕之后再建立重定向的那个文件吧~

比如一个简单的方法:

1) ls | grep * 1>aaa.log

2) 一个更简单的 ls | 1>aaa.log

猜你喜欢

转载自fantaxy025025.iteye.com/blog/760264
今日推荐