如果想写个Shell脚本能按反向打印出命令行中给的参数,可以这样写:
#!/bin/bash
((count=$#))
while true
do
echo -e “/$$count”
((count=`expr $count-1`))
if [ $count -eq 0 ]
then break
fi
done
命名为print,并保存在目录/root/bash下,然后在终端运行 “#bash print a b c”结果却是:
$3
$2
$1
我的本意是让shell输出位置参数$count的实参$($count),但shell只执行了第一步的替换,即将$count替换成对应的位置参数,却没有把$($count)替换成相应的实参字符串。原来shell在默认的情况下会忽略间接变量引用的情况,如果要引用间接变量,需要使用eval命令,脚本修改如下:
#!/bin/bash
((count=$#))
while true
do
eval echo -e “/$$count”
((count=`expr $count-1`))
if [ $count -eq 0 ]
then break
fi
done
eval告诉shell,后面的这条命令含有间接引用变量,shell为了保证间接引用变量的语义,会先进行变量代换,即先把$count替换成相应的位置参数,然后再执行echo命令,这样结果就正确了。
也可以这样:
#!/bin/bash
((count=$#))
cmd=echo
while true
do
cmd="$cmd /$$count"
((count=`expr $count-1`))
if [ $count -eq 0 ]
then break
fi
done
eval $cmd
bash开始时为count变量赋值,要用算术运算表达式((count=$#))或者let “count=$#”,如果用语句count=$#赋值,则shell认为count为字符串,运行到下面条件测试,与0比较的时候,shell会提示出错。
eval命令用法
最新推荐文章于 2023-09-09 22:58:48 发布