对 eval 命令的理解
eval
格式:eval [argument...]
可以二次迭代参数中的引用变量,然后将参数作为命令,在shell中执行
如果是多个参数,那么变量替换之后必须符合某个命令的格式,否则eval会报错“**未找到命令”
与echo的区别:
- echo 对后面参数中的引用变量只能进行一次迭代
- echo 后面的参数是作为字符串输出到命令行,而不是作为命令在shell中执行
示例:
一次迭代可以解析引用变量的嵌套
# 引用变量的嵌套
file="txt.txt"
dir="~/testcase/$file"
t="cat $dir"
echo $t
eval echo $t
eval $t # 输出结果
# $t 解析为 cat ~/testcase/txt.txt,然后作为 echo 命令的参数,输出到终端
cat ~/testcase/txt.txt
# 先将 $t 解析为 cat /home/lfp/testcase/txt.txt,再将 echo cat /home/lfp/testcase/txt.txt 作为命令,
# 在shell中执行,echo 命令的作用便是将后面的参数作为字符串输出到终端
cat /home/lfp/testcase/txt.txt
# 先将 $t 解析为 cat /home/lfp/testcase/txt.txt,再将 cat /home/lfp/testcase/txt.txt 作为命令,在shell中执行
test case txt file # 此为 txt.txt 文件中的内容,作为cat 命令的执行结果输出到终端
二次迭代可以解析,一次迭代后,和参数中的'$',组成的,新的引用变量
lfp@legion:~$ days=365
lfp@legion:~$ year=days
lfp@legion:~$ echo $year
days
lfp@legion:~$ echo \$$year
$days
# 第一次 $year 解析为 days,跟参数中的 $,组合成新的引用变量 $days,变为 eval echo $days
# 第二次 $days 解析为365,变为 eval echo 365,消除了引用变量,于是将 echo 365 作为命令,在shell中执行
# 替换之后的参数为 echo 365 符合echo命令格式,于是在shell中执行 echo 365 这个命令,输出 365
lfp@legion:~$ eval echo \$$year
365 # 参数 \$$year 被两次解析为365,eval 便将 365 作为命令,在shell中执行,但是365 不是一个命令,所以报错
lfp@legion:~$ eval \$$year
365:未找到命令
官方例子改编
# 定义两个变量
lfp@legion:~$ foo=10 x=foo # 一般命令的执行,对于引用变量只解析一次
# 下面命令的执行结果是 y=$foo
lfp@legion:~$ y='$'$x # 先解析为 '$'foo,再赋值给变量 y
lfp@legion:~$ echo $y
$foo
lfp@legion:~$ echo y='$'$x # 先解析为 y='$'foo,再作为echo命令的参数,输出到终端
y=$foo
lfp@legion:~$ echo $y
$foo # eval 可以两次迭代引用变量
lfp@legion:~$ eval echo y='$'$x
y=10
lfp@legion:~$ echo $y # y=10 未作为命令在shell中执行,变量 y 的值未改变
$foo
lfp@legion:~$ eval y='$'$x
lfp@legion:~$ echo $y # y=10 作为命令在shell中执行,变量 y 的值被改变
10
测试3次迭代
lfp@legion:~$ a=b
lfp@legion:~$ b=c
lfp@legion:~$ c=d
lfp@legion:~$ eval echo $a
b
lfp@legion:~$ eval echo '$'$a
c
# 自己测试没有3次迭代
lfp@legion:~$ eval echo '$''$'$a
21947b
参考
https://unix.stackexchange.com/a/23115
http://cn.linux.vbird.org/linux_basic/Mandrake9.0/0320bash.php#eval
对 eval 命令的理解的更多相关文章
- 理解shell的eval命令
看以下两条命令:[zhangsan@XEN /sys]$ a="ls";b="\$a";c="$b";"$c"Hey! ...
- 【转】exec xargs的区别 另附eval命令介绍
-exec: 对符合条件的文件执行所给的Linux 命令,执行exec后面的shell脚本.脚本中,{}表示命令的参数即为所找到的文件,以:表示comman命令的结束.\是转义符,因为分号在命令中还 ...
- shell eval命令
1. eval command-line 其中command-line是在终端上键入的一条普通命令行.然而当在它前面放上eval时,其结果是shell在执行命令行之前扫描它两次.如: pipe=&qu ...
- Linux命令行–理解Linux文件权限(转)
6.1.1 /etc/passwd文件 /etc/passwd:包含系统用户账户列表以及每个用户的基本配置信息 每个条目有七个字段,每个字段用冒号隔开 登录用户名 用户密码 用户账户的UID 用户账户 ...
- linux eval命令
eval 功能说明:重新运算求出参数的内容.语 法:eval [参数]补充说明:eval可读取一连串的参数,然后再依参数本身的特性来执行.参 数:参数不限数目,彼此之间用分号分开. 1.eval命令将 ...
- Redisson使用起来很方便,但是需要redis环境支持eval命令
Redisson使用起来很方便,但是需要redis环境支持eval命令,否则一切都是悲剧,比如me.结果还是要用RedisCommands去写一套.例子就如下,获得一个RLock锁对象,然后tryLo ...
- shell中eval命令妙用——变量嵌套替换
eval命令妙用--变量嵌套替换 eval命令在Linux下的应用非常广泛,在写脚本的时候遇到一个变量嵌套的问题,用eval迎刃而解,略试不爽啊. var1="hello" i=1 ...
- shell解析命令行的过程以及eval命令
本文说明的是一条linux命令在执行时大致要经过哪些过程?以及这些过程的大致顺序. 1.1 shell解析命令行 shell读取和执行命令时的大致操作过程如下图: 以执行以下命令为例: echo -e ...
- Linux里的eval命令
这个命令之前没有用过,在网上查了一下资料,觉得人家写的很好,所以复制过来了. 标题:linux命令eval的用法 链接:http://blog.chinaunix.net/uid-21411227 ...
随机推荐
- Hadoop学习笔记(一)——安装与配置
操作系统:Ubuntu 15.04; Hadoop version: 2.6.4 参考文献: Ubuntu上搭建Hadoop环境(单机模式+伪分布模式)
- vue无法自动打开浏览器
原文链接: 点我 如果不能自动打开浏览器,是因为没有安装插件. 插件安装的方法1.安装插件,在cmd中输入: $ npm i open-browser-webpack-plugin --save这里的 ...
- 数学--数论--HDU-2698 Maximum Multiple(规律)
Given an integer nn, Chiaki would like to find three positive integers xx, yy and zzsuch that: n=x+y ...
- 数学--数论--HDU 6063 RXD and math (跟莫比乌斯没有半毛钱关系的打表)
RXD is a good mathematician. One day he wants to calculate: output the answer module 109+7. p1,p2,p3 ...
- linux上github的简单使用
Git是一个分布式的版本控制系统,最初由Linus Torvalds编写,用作Linux内核代码的管理.在推出后,Git在其它项目中也取得了很大成功,尤其是在Ruby社区中.目前,包括Rubinius ...
- Linux安装maven(详细教程)
一.简介 Maven是意第绪语,意思是“知识的积累者”,最初是为了简化Jakarta Turbine项目中的构建过程.有几个项目,每个项目都有自己的Ant构建文件,所有项目都略有不同.JAR已检入CV ...
- spring学习笔记(六)自定义spring-boot-starter(2)
上篇文章我们主要讲了spring自动装配的原理,我们知道了springboot在启动的时候会自动去读.factories文件,在factories文件中,autoConfiguration对应的就是我 ...
- node基础知识-说说对node的理解
一.说说你对node的理解 从定义+特点+作用来说对node的理解 定义:node是基于Chrmo v8引擎的JavaScript运行环境; 特点:具有事件驱动,非阻塞I/O模型,高并发和轻量级,单线 ...
- XSS检测总结
XSS漏洞介绍 跨站脚本XSS是一种针对网站应用程序的安全漏洞攻击技术.恶意攻击者往web页面插入恶意的Script代码,当用于浏览该页时,嵌入web中的恶意代码就会被执行,从而达到恶意攻击用 ...
- GP1UM26(78)1RK远程红外遥控接收IC数据手册学习
1.Features 该系列IC具有多种BMP带通频率可供选择,典型的GP1UM261RK带通频率为38KHz,内部的前置放大器等放大电路工作频率均为38KHz. Compact紧凑型,体积小 2.i ...