shell 在执行某个命令的时候,会返回一个返回值,该返回值保存在 shell 变量 ? == 0 时,表示执行成功;当 $? == 1 时,表示执行失败。 有时候,下一条命令依赖前一条命令是否执行成功。如:在成功地执行一条命令之后再执行另一条命令,或者在一条命令执行失败后再执行另一条命令等。shell 提供了 && 和 || 来实现命令执行控制的功能,shell 将根据 && 或 || 前面命令的返回值来控制其后面命令的执行。
&&(命令执行控制)
语法格式如下:
command1 && command2 [&& command3 ...]
1 命令之间使用 && 连接,实现逻辑与的功能。
2 只有在 && 左边的命令返回真(命令返回值 $? == 0),&& 右边的命令才会被执行。
3 只要有一个命令返回假(命令返回值 $? == 1),后面的命令就不会被执行。
#demo1
www@ubuntu4:~/bin/lua$ ls lua.sh www@ubuntu4:~/bin/lua$ cp ./lua.sh ./lua_cp.sh && rm ./lua.sh && echo "success" success www@ubuntu4:~/bin/lua$ ls lua_cp.sh
说明:命令首先从 /home/www/bin/lua/lua.sh 文件复制 到当前目录重命名为lua_cp.sh,执行成功后,使用 rm命令 删除源文件lua.sh;如果删除成功则输出提示信息。
||(命令执行控制)
语法格式如下:
command1 || command2 [|| command3 ...]
1 命令之间使用 || 连接,实现逻辑或的功能。
2 只有在 || 左边的命令返回假(命令返回值 ? == 0),后面的命令就不会被执行。
#demo1
www@ubuntu4:~/bin/lua$ ls lua_cp.sh www@ubuntu4:~/bin/lua$ rm ./tinywan.sh && echo "success" || echo "fail" rm: cannot remove ‘./tinywan.sh’: No such file or directory fail
说明:目录下不存在文件 tinywan.sh,将输出提示信息“fail”,删除失败
#demo2
www@ubuntu4:~/bin/lua$ ls lua_cp.sh www@ubuntu4:~/bin/lua$ rm ./lua_cp.sh && echo "success" || echo "fail" success www@ubuntu4:~/bin/lua$ ls www@ubuntu4:~/bin/lua$
说明:目录下存在文件tinywan.sh,将输出提示信息“success”,删除成功
$0 这个程式的执行名字
$n 这个程式的第n个参数值,n=1..9
$* 这个程式的所有参数,此选项参数可超过9个。
$# 这个程式的参数个数
$$ 这个程式的PID(脚本运行的当前进程ID号)
$! 执行上一个背景指令的PID(后台运行的最后一个进程的进程ID号) 执行上一个背景指令的PID(后台运行的最后一个进程的进程ID号) 是父ID????
$? 状态返回值,执行上一个指令的返回值 (显示最后命令的退出状态。0表示没有错误,其他任何值表明有错误)
$- (这里是中短横)显示shell使用的当前选项,与set命令功能相同
$@ 跟$*类似,但是可以当作数组用 然后的话${#@}就是把参数列表当作的数组的长度吗? 看看 关于数组 /node-admin/15463
$# 是传给脚本的参数个数
$0 是脚本本身的名字
$1 是传递给该shell脚本的第一个参数
$2 是传递给该shell脚本的第二个参数
$@ 是传给脚本的所有参数的列表
$* 是以一个单字符串显示所有向脚本传递的参数,与位置变量不同,参数可超过9个
$$ 是脚本运行的当前进程ID号
$? 是显示最后命令的退出状态,状态返回值,0表示没有错误,其他表示有错
# vim xx.sh #这是用函数方法
#!/bin/bash
#
xx(){
echo "1111111111"
echo $0 # 脚本名称
echo "2222222222"
echo $1 #第一个参数
echo "3333333333"
echo $* #参数值列表
echo "4444444444"
echo $@ #参数值列表
echo "55555555"
echo $$ # 本进程的进程id???
echo "66666666"
echo $!
echo "77777777"
echo $? #状态返回值
echo "8888888888"
echo $-
echo "999999999"
echo ${@} #参数值列表
echo "AAAAAAAAAAA"
echo ${*} #参数值列表
echo "BBBBBBBB"
echo ${#} #参数个数
echo "CCCCCCCCC"
echo ${#@} #参数个数
echo "DDDDDDDDD"
echo ${@#} #参数值列表
echo "EEEEEEEEE"
echo ${#*} #参数个数
echo "FFFFFF"
echo $# #参数个数
}
xx a b c
# bash xx.sh #结果如下
1111111111
xx.sh
2222222222
a
3333333333
a b c
4444444444
a b c
55555555
26774
66666666
77777777
0
8888888888
hB
999999999
a b c
AAAAAAAAAAA
a b c
BBBBBBBB
3
CCCCCCCCC
3
DDDDDDDDD
a b c
EEEEEEEEE
3
FFFFFF
3
[root@ha1 test]# vim yyy.sh #这是用脚本文件名的方法,执行脚本后发现结果与函数是一样的
echo $@
echo "55555555"
echo $$
echo "66666666"
echo $!
echo "77777777"
echo $?
echo "8888888888"
echo $-
echo "999999999"
echo ${@}
echo "AAAAAAAAAAA"
echo ${*}
echo "BBBBBBBB"
echo ${#}
echo "CCCCCCCCC"
echo ${#@}
echo "DDDDDDDDD"
echo ${@#}
echo "EEEEEEEEE"
echo ${#*}
echo "FFFFFFFF"
echo $#
[root@ha1 test]# ./yyy.sh a b c #执行脚本
1111111111
./yyy.sh
2222222222
a
3333333333
a b c
4444444444
a b c
55555555
28313
66666666
77777777
0
8888888888
hB
999999999
a b c
AAAAAAAAAAA
a b c
BBBBBBBB
3
CCCCCCCCC
3
DDDDDDDDD
a b c
EEEEEEEEE
3
FFFFFFFF
3
$0 当前脚本的文件名 $1 ~ $n? 位置参数,为从1开始的数字,当n超过9后,使用${n},例如${10},$1是第一个参数,$2是第二个参数,${10}是第十个参数 #美元符号 1 $# 传入脚本的参数的个数 #美元符号 井号 $* 所有的位置参数,但视为一个字符串 #美元符号 星号 $@ 所有以空白隔开的位置参数,即代表各位置参数组成的串行(每个都作为独立的字符串,可用 “for 变量 in 串行” 循环输出)。 # 美元符号 艾特符号 $? 当前Shell进程中,上一个命令的返回值,如果上一个命令成功执行则$?的值为0,否则为其他非零值,常用做if语句条件 # 美元符号 问号 $$ 当前Shell进程的pid #两个美元符号 $! 后台运行的最后一个进程的pid # 美元符号 感叹号 $- 显示Shell使用的当前选项 # 美元符号 中短横 (减号) $_ 之前命令的最后一个参数 # 美元符号 下短横
#demo1
#!/bin/bash echo "\$# = 传入脚本的参数的个数: $#" echo "\$0 = 当前脚本的文件名: $0" echo "\$1 = first : $1" echo "\$2 = second: $2" echo "\$@ = 所有以空白隔开的位置参数: $@" echo "\$* = 所有的位置参数,但视为一个字符串: $*" echo "\$$ = 当前Shell进程的pid process id: $$" echo "\$? = 当前Shell进程中,上一个命令的返回值: $?"
执行结果:
www@ubuntu4:~/bin$ ./test2.sh var1 var2 var3 var4 var5 var6 $# = 传入脚本的参数的个数: 6 $0 = 当前脚本的文件名: ./test2.sh $1 = first : var1 $2 = second: var2 $@ = 所有以空白隔开的位置参数: var1 var2 var3 var4 var5 var6 $* = 所有的位置参数,但视为一个字符串: var1 var2 var3 var4 var5 var6 $$ = 当前Shell进程的pid process id: 167270 $? = 当前Shell进程中,上一个命令的返回值: 0
在 [[ 判断式 ]] 中,如果使用 == 或 != ,且在这两个运算符右方的字符串没有加上单引号或双引号,则 == 和 != 会视为想要对比该字符串所形成的“样式”,如果相等,传回0,如果不符,传回1。
#!/bin/bash a="str" if [[ $a == ??? ]]; then echo "Match" fi
行4,[[ a 的值,对比样式 ??? (3个字符的字符串)。
但如果把行4改成:
if [[ $a == "???" ]]; then
那意思就不同了,此时 == 变成了是判断 $a 和 字符串 ??? 是否相等。