linux下的eval命令

1. eval command-line

其中commandline是在终端上键入的一条普通命令行。然而当在它前面放上eval时,其结果是shell在执行命令行之前扫描它两次。eval命令将会首先扫描命令行进行所有的替换,然后再执行命令。该命令使用于那些一次扫描无法实现其功能的变量。该命令对变量进行两次扫描。这些需要进行两次扫描的变量有时候被称为复杂变量。如:

pipe="|"

eval ls $pipe wc -l

如图:

shell1次扫描命令行时,它替换出pipe的值|,接着eval使它再次扫描命令行,这时shell把|作为管道符号了。

如果变量中包含任何需要shell直接在命令行中看到的字符(不是替换的结果),就可以使用eval。命令行结束符(;| &),Io重定向符(< >)和引号就属于对shell具有特殊意义的符号,必须直接出现在命令行中。

eval也可以用于回显简单变量,不一定是复杂变量。

如:

NAME=NO

eval echo $NAME等价于echo $NAME

2. eval echo \$$#取得最后一个参数

如:cat last

eval echo \$$#

./last one two three four

four

如图:

第一遍扫描后,shell把反斜杠去掉了。当shell再次扫描该行时,它替换了$4的值,并执行echo命令

3.以下示意如何用eval命令创建指向变量的“指针”:

x=100

ptrx=x

eval echo \$$ptrx指向ptrx,用这里的方法可以理解b中的例子

100 打印100

eval $ptrx=5050存到ptrx指向的变量中。

echo $x

50 打印50

如图:


【与``和$()的区别】

在$(命令)中,命令部分的内容不会被父shell解析,而反引号的部分却会被解析,例如`\`,`$`,```
举个例子
> $(echo "first second"|awk "\$2==\"second\" {print $1}") 执行是成功的,执行结果为first
> a=`echo "first second"|awk "\$2==\"second\" {print $1}"`执行失败
> awk: line 1: syntax error at or near ==

原因是反引号内的内容会被父shell解释,所以\$2被父shell解释后变成了$2, 而$2在子shell里面是会被解析的,而默认的
$2代表子shell的第二个参数,显然为空,然后继续被awk解释,然后就报了上述的错误

其实还有另外一个错误,print $1,这里的$符号也是要被父shell解释的,则是不对的

最后改为
> `echo "first second"|awk "\\$2==\"second\" {print \\$2}`

    1.反引号其本身就对\进行了转义,保留了其本身意思,如果我们想在反引号中起到\的特殊意义,我们必须使用2个\来进行表示。

    2.所以我们可以简单的想象成反引号中: \\ = \

    3.$()中则不需要考虑\的问题,与我们平常使用的一样:\ = \



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值