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
    评论
### 回答1: Linux中的eval命令是一个用于将字符串转换为命令行语句并执行的命令。它将解析并执行由引号括起来的参数作为一条命令,可以将变量、函数和算术运算符的值作为参数传递到该命令eval命令在编写shell脚本时非常有用,可以让你将动态生成的代码作为命令执行。然而,使用eval命令时要非常小心,因为它可能会有安全问题,特别是当它的参数来自不可信的来源时。 ### 回答2: eval命令Linux系统中的一个内置命令,用于执行一个字符串作为命令并在当前shell环境中运行。eval命令的基本语法是"eval [字符串]"。 eval命令的主要作用是将字符串作为命令执行,字符串中可以包含命令、变量、表达式等,eval命令会将字符串作为一个整体解析并执行。这个功能非常有用,特别是在需要动态构建命令或者在脚本中使用变量时。 eval命令的常见用法如下: 1. 动态构建命令: 可以通过将命令和变量组合成字符串,然后使用eval命令来执行。例如,可以使用eval命令来循环执行一组命令,或者动态构建带有变量的复杂命令。 2. 执行字符串表达式: eval命令可以将字符串作为表达式进行求值。这在需要动态计算数学表达式时非常有用。例如,可以将一个包含数学计算的字符串作为参数传递给eval命令,然后返回计算结果。 3. 使用变量: eval命令可以解析字符串中的变量,并将其替换为实际的值。这样可以在脚本中灵活地使用变量,并且可以根据需要在运行时进行动态更改。 然而,eval命令需要小心使用,因为它可以执行任何命令,可能导致潜在的安全风险。应该避免将来自不受信任的源的字符串传递给eval命令,以防止执行恶意代码。同时,应该谨慎处理字符串中的变量,确保不会受到注入攻击的风险。 总之,eval命令Linux系统中非常强大和灵活的一个命令,可以用于动态构建和执行命令、求值表达式以及使用变量。适当地使用eval命令可以提高脚本的灵活性和效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值