主要包括一下几种
${var}
$(cmd)
()和{}
$((exp))
${var:-string},${var:+string},${var:=string},${var:?string}
$(var%pattern),$(var%%pattern),$(var#pattern),$(var##pattern)
注意:$(cmd)只输出标准输入,如果命令执行错误,则无输出
二者都用于执行一串命令,指令之间用;分开,注意:括号内的数据重导向只影响括号内部的指令输入输出,不影响括号外部的指令
不同之处如下:
运行方式:
1)()重新开启一个shell运行命令,{}在当前shell运行
语法:
1)()最后一条指令不需要; , {}最后一条指令需要;
2) {}第一个指令和左括号需要有空格,()不需要
下面是一个简单的例子
[java] view plaincopy
<span style="font-size:10px;">$ var=test
$ (var=notest; echo $var) ###变量var值为notest,此是在子shell中有效
notest
$ echo $var ###父shell中值仍为test
test
$ { var=notest; echo $var;} ###注意左括号和var之间要有一个空格
notest
$ echo $var ###父shell中的var变量的值变为了notest
notest
$ { var1=test1;var2=test2;echo $var1>a;echo $var2;} ###输出test1被重定向到文件a中,
test2 ###而test2输出则仍输出到标准输出中。
$ cat a
test1
$ { var1=test1;var2=test2;echo $var1;echo $var2;}>a ###括号内命令的标准输出全部被重定向到文件a中
$ cat a
test1
test2</span>
例子如下
[java] view plaincopy
<span style="font-size:10px;">$ echo $((3+2))
5
$ echo $((3>2))
1
$ echo $((25<3 ? 2:3))
3
$ echo $var
$ echo $((var=2+3))
5
$ echo $var
5
$ echo $((var++))
5
$ echo $var
6
$</span>
替换:
${var:-string} 若var为空,${var:-string}值为string
${var:=string} 与${var:-string}功能类型,不过${var:=string} 将string值赋给var变量
${var:=string} 判断某个变量是否赋值,没有的话则给它赋上一个默认值
${var:+string}的替换规则和${var:=string}相反,即只有当var不是空的时候才替换成string,若var为空时则不替换或者说是替换成变量 var的值,即空值
匹配:
${var%pattern}和${var%%pattern}表示从最右边(即结尾)匹配的
${var#pattern} 和${var##pattern}从最左边(即开头)匹配的
基本要素:
[ ] 两个符号左右都要有空格分隔
内部操作符与操作变量之间要有空格:如 [ “a” = “b” ]
字符串比较中,> < 需要写成\> \< 进行转义
[ ] 中字符串或者${}变量尽量使用"" 双引号扩住,避免值未定义引用而出错的好办法
[ ] 中可以使用 �Ca �Co 进行逻辑运算
[ ] 是bash 内置命令:[ is a shell builtin
基本要素:
[[ ]] 两个符号左右都要有空格分隔
内部操作符与操作变量之间要有空格:如 [[ “a” = “b” ]]
字符串比较中,可以直接使用 > < 无需转义
[[ ]] 中字符串或者${}变量尽量如未使用"" 双引号扩住的话,会进行模式和元字符匹配
[root@localhostkuohao]# [[ "ab"=a* ]] && echo "ok"
ok
[[] ] 内部可以使用 && || 进行逻辑运算
[[ ]] 是bash keyword:[[ is a shell keyword
[[ ]] 其他用法都和[ ] 一样
[[ ]] 和 [ ] 都可以和 ! 配合使用
优先级 ! > && > ||
逻辑运算符 < 关系运算符
逻辑运算符 : ! && || -a -o
关系运算符 : < > \> \< == = != �C eq �Cne -gt -ge �Clt -le
-----------------------------------------------------------------------------
-----------------------------------------------------------------------------
①[[是 bash 程序语言的关键字。并不是一个命令,[[ ]] 结构比[ ]结构更加通用。在[[和]]之间所有的字符都不会发生文件名扩展或者单词分割,但是会发生参数扩展和命令替换。
②支持字符串的模式匹配,使用=~操作符时甚至支持shell的正则表达式。字符串比较时可以把右边的作为一个模式,而不仅仅是一个字符串,比如[[ hello == hell? ]],结果为真。[[ ]] 中匹配字符串或通配符,不需要引号。
③使用[[ ... ]]条件判断结构,而不是[... ],能够防止脚本中的许多逻辑错误。比如,&&、||、<和> 操作符能够正常存在于[[ ]]条件判断结构中,但是如果出现在[ ]结构中的话,会报错。
④bash把双中括号中的表达式看作一个单独的元素,并返回一个退出状态码。
使用[[ ... ]]条件判断结构, 而不是[ ... ], 能够防止脚本中的许多逻辑错误. 比如,&&, ||, <, 和> 操作符能够正常存在于[[]]条件判断结构中, 但是如果出现在[ ]结构中的话, 会报错。
小括号部分转自:http://my.oschina.net/xiangxw/blog/11407
中括号部分转自:http://blog.csdn.net/hittata/article/details/8049665