041-bash下: () {} [] [[]] (())的解释

bash下有不少像{}、[]等一些符号命令,下面是我对一些经常使用的符号命令的学习笔记,如有错误或纰漏望各位兄弟指正。

1、.(source)
.(点)与source命令同样,从文件中读取并执行命令,不管该文件是否都有可执行权限都可以正确的执行。且是在当前shell下执行,而不是产生一个子shell来执行(咱们一般使用“./filename.sh”去执行一个文件是在当前shell下产生一个子shell去执行的)。因此在设置bash的环境的变量时,就必须用该命令或者source命令去执行设置的环境变量才会对当前shell生效,以下:
 shell

for i in /etc/profile.d/*.sh ; do
    if [ -r "$i" ]; then
        . $i
    fi
done
bash


2、:
: 该命令什么都不作,但执行后会返回一个正确的退出代码,即exit 0。好比在if语句中,then后面不想作任何操做,可是又不能空着,这时就可使用“:”来解决,以下:
 app

if [ "$i" -ne 1 ];then
    :
else
    echo "$i is not equal 1"
fi
less


3、()
() 将多个命令组合在一块儿执行,至关于一个命令组。

4、{}
{}  和()相似,也是将多个命令组合在一块儿。它们之间的区别是,()是在产生的子shell下执行,而{}是在当前的shell下执行。这与前面讲到是使用".  filename.sh"和"./filename.sh"的区别同样。举一个很简单的例子:
 学习

# A=123
 
(A=abc;echo $A);echo $A
abc
123

# { A=abc;echo $A; };echo $A
abc
abc
测试


从上面的示例能够看出,当在()中赋值的变量,影响的只是自身的子shell,而不能将该值赋给父shell,由于“父亲不能继承儿子”。而在{}中赋值的变量,由于就在当前的shell执行的,因此就能改变原来变量的值。
注意:()里面两边能够不使用空格,{}里面两边必须使用空格,且最后一个命令也须要以“;”结尾,表示命令结束。

5、[](test)
[] 与test命令同样,用于比较值以及检查文件类型。以下:
一、[ "$A" = 123 ]:是字符串的测试,以测试 $A 是否为 一、二、3 这三个连续的"文字"。
二、[ "$A" -eq 123 ]:是整数的测试,以测试 $A 是否等于"一百二十三"。
三、[ -e "$A" ]:是关于文件的测试,以测试 123 这份"文件"是否存在。

6、[[]]
[[]]能够说是[]的“加强版”,它可以将多个test命令支持的测试组合起来,例如:
 spa

# [[ (-d "$HOME") && (-w "$HOME") ]] && echo echo "home is a writable directory"  code

home is a writable directory继承


至于这二者的区别有位仁兄已经写的很清楚了,我将其整理一下:
 进程

数字测试: -eq -ne -lt -le -gt -ge,[[ ]]同 [ ]一致
文件测试: -r、-l、-w、-x、-f、-d、-s、-nt、-ot,[[ ]]同 [ ]一致
字符串测试: > < =(同==) != -n -z,不可以使用“<=”和“>=”,[[ ]]同 [ ]
<

SPAN style="COLOR: rgb(0,1,2)">一致,但在[]中,>和<必须使用\进行转义,即\>和\<
逻辑测试: []为 -a -o ! [[ ]] 为&& || !
数学运算: [] 不可使用 [[ ]]可使用+ - */ %
组合: 都可用各自逻辑符号链接的数字(运算)测试、文件测试、字符测试


拿这二者对字符串的测试举一个例子,以下:
 

# [ a \> 1 ] && echo ture || echo false
ture
# [[ a > 1 ]] && echo ture || echo false
ture


字符串的比较是根据相应的ASCII码来比较的,因此a>1是成立的。若是有兴趣也能够思考一下为何会出现下面的结果?
 

# [[ a > 1 ]] && echo ture || echo false
ture


7、(())
(())专门来作数值运算,若是表达式求值为 0,则设置退出状态为 1;若是求值为非 0 值,则设置为 0。不须要对 (( 和 )) 之间的操做符转义。算术只对整数进行。除 0 会产生错误,但不会产生溢出。能够执行 C 语言中常见的算术、逻辑和位操做。以下:
 

# ((i=1+99));echo $i
100


也能:
 

# i=99;((i++));echo $i
100


除此以外,也可使用$(())直接进行数值运算,以下:
 

# echo $((2**3))
8


注意:使用 (( )) 时,不须要空格分隔各值和运算符,使用[]和[[ ]] 时须要用空格分隔各值和运算符。 
  
  
组合判断: 
  
if [ $a -ne 0 ] && [ $b -lt 3 ] || [ $c -gt 5 ] 
then 
#你在这里加其余操做 
fi 
  
  
////////////////////////// 
  
7.1.1.1. 和if使用的表达式 下表包含了一个组成 TEST-COMMAND 命令或者命令列表,称做 “要素primaries” 的概览。这些primaries放置在方括号中来表示一个条件表达式的测试。 表 7.1. 主表达式Primary 意义
[ -a FILE ] 若是 FILE 存在则为真。
[ -b FILE ] 若是 FILE 存在且是一个块特殊文件则为真。
[ -c FILE ] 若是 FILE 存在且是一个字特殊文件则为真。
[ -d FILE ] 若是 FILE 存在且是一个目录则为真。
[ -e FILE ] 若是 FILE 存在则为真。
[ -f FILE ] 若是 FILE 存在且是一个普通文件则为真。
[ -g FILE ] 若是 FILE 存在且已经设置了SGID则为真。
[ -h FILE ] 若是 FILE 存在且是一个符号链接则为真。
[ -k FILE ] 若是 FILE 存在且已经设置了粘制位则为真。
[ -p FILE ] 若是 FILE 存在且是一个名字管道(F若是O)则为真。
[ -r FILE ] 若是 FILE 存在且是可读的则为真。
[ -s FILE ] 若是 FILE 存在且大小不为0则为真。
[ -t FD ] 若是文件描述符 FD 打开且指向一个终端则为真。
[ -u FILE ] 若是 FILE 存在且设置了SUID (set user ID)则为真。
[ -w FILE ] 若是 FILE 若是 FILE 存在且是可写的则为真。
[ -x FILE ] 若是 FILE 存在且是可执行的则为真。
[ -O FILE ] 若是 FILE 存在且属有效用户ID则为真。
[ -G FILE ] 若是 FILE 存在且属有效用户组则为真。
[ -L FILE ] 若是 FILE 存在且是一个符号链接则为真。
[ -N FILE ] 若是 FILE 存在 and has been mod若是ied since it was last read则为真。
[ -S FILE ] 若是 FILE 存在且是一个套接字则为真。
[ FILE1 -nt FILE2 ] 若是 FILE1 has been changed more recently than FILE2, or 若是 FILE1FILE2 does not则为真。
exists and [ FILE1 -ot FILE2 ] 若是 FILE1 比 FILE2 要老, 或者 FILE2 存在且 FILE1 不存在则为真。
[ FILE1 -ef FILE2 ] 若是 FILE1 和 FILE2 指向相同的设备和节点号则为真。
[ -o OPTIONNAME ] 若是 shell选项 “OPTIONNAME” 开启则为真。
[ -z STRING ] “STRING” 的长度为零则为真。
[ -n STRING ] or [ STRING ] “STRING” 的长度为非零 non-zero则为真。
[ STRING1 == STRING2 ] 若是2个字符串相同。 “=” may be used instead of “==” for strict POSIX compliance则为真。
[ STRING1 != STRING2 ] 若是字符串不相等则为真。
[ STRING1 < STRING2 ] 若是 “STRING1” sorts before “STRING2” lexicographically in the current locale则为真。
[ STRING1 > STRING2 ] 若是 “STRING1” sorts after “STRING2” lexicographically in the current locale则为真。
[ ARG1 OP ARG2 ] “OP” is one of -eq, -ne, -lt, -le, -gt or -ge.These arithmetic binary operators return true if “ARG1” is equal to,not equal to, less than, less than or equal to, greater than, orgreater than or equal to “ARG2”, respectively. “ARG1” and “ARG2” areintegers. 表达式能够借如下操做符组合起来,以降序列出:listed in decreasing order ofprecedence

 表 7.2. 组合表达式操做 效果 [ ! EXPR ] 若是 EXPR 是false则为真。 [ ( EXPR ) ] 返回 EXPR的值。这样能够用来忽略正常的操做符优先级。 [ EXPR1 -a EXPR2 ] 若是 EXPR1 and EXPR2 全真则为真。 [ EXPR1 -o EXPR2 ] 若是 EXPR1 或者 EXPR2 为真则为真。 [ (或做 test)内建命令对条件表达式使用一系列基于参数数量的规则来求值。更多关于这个主题的信        ////////////////////////     -eq 等于 -ne 不等于 -gt 大于 -lt 小于 -le 小于等于 -ge 大于等于 -z 空串 * = 两个字符相等 * != 两个字符不等 * -n 非空串    ///////////////////////     (7)保留字符及其含义 $ shell变量名的开始,如$var | 管道,将标准输出转到下一个命令的标准输入 # 注释开始 & 在后台执行一个进程 ? 匹配一个字符 * 匹配0到多个字符(与DOS不一样,可在文件名中间使用,而且含.) $- 使用set及执行时传递给shell的标志位 $! 最后一个子进程的进程号 $# 传递给shell script的参数个数 $* 传递给shell script的参数 $@ 全部参数,个别的用双引号括起来 $? 上一个命令的返回代码 $0 当前shell的名字 $n (n:1-) 位置参数 $$ 进程标识号(Process Identifier Number, PID) >file 输出重定向 <file 输入重定向 `command` 命令替换,如 filename=`basename /usr/local/bin/tcsh` >>fiile 输出重定向,append 转义符及单引号: $echo "$HOME $PATH" /home/hbwork /opt/kde/bin:/usr/local/bin:/bin:/usr/bin:/usr/X11R6/bin: $echo '$HOME $PATH' $HOME $PATH $echo \\$HOME $PATH $HOME /opt/kde/bin:/usr/local/bin:/bin:/usr/bin:/usr/X11R6/bin:/home/hbw ork/bin 其余: $dir=ls $$dir $alias dir ls $dir ls > filelist ls >> filelist wc -l < filelist wc -l filelist sleep 5; echo 5 seconds reaches; ls -l ps ax |egrep inetd find / -name core -exec rm {} \\; & filename=`date "+%Y%m%d"`.log 2. shell变量 变量:表明某些值的符号,如$HOME,cd命令查找$HOME,在计算机语言中可使用变量能够 进行多种运算和控制。 Bourne Shell有以下四种变量: .用户自定义变量 .位置变量即 shell script之参数 .预约义变量(特殊变量) .环境变量(参考shell定制部分)        /////////////        old_tag=`hg tags | grep db1_V0_ | sed -n -e 1p | sed -e "s/ .*//"` echo $old_tag index=`expr index "$old_tag" _V0_` echo $index new_tag="db1_V0_"`printf "%04d" $((${old_tag:index+3}+1))` echo $new_tag    db1_V0_0002 4 db1_V0_0003     “.*”匹配剩余的0个或多个字符 替换全部的"s/1/2/g"

相关文章
相关标签/搜索