在linux中,&和&&,|和||介紹如下:
& ?表示任務在后臺執行,如要在后臺運行redis-server,則有? redis-server &
&& 表示前一條命令執行成功時,才執行后一條命令 ,如 echo ‘1‘ && echo ‘2’
| 表示管道,上一條命令的輸出,作為下一條命令參數,如 echo ‘yes’ | wc -l
|| 表示上一條命令執行失敗后,才執行下一條命令,如 cat nofile || echo “fail”
shell中&&和||的使用方法
&&運算符:
command1 ?&& command2
&&左邊的命令(命令1)返回真(即返回0,成功被執行)后,&&右邊的命令(命令2)才能夠被執行;換句話說,“如果這個命令執行成功&&那么執行這個命令”。
語法格式如下:
? ? command1 && command2 [&& command3 …]
1 命令之間使用 && 連接,實現邏輯與的功能。
2 只有在 && 左邊的命令返回真(命令返回值 $? == 0),&& 右邊的命令才會被執行。
3 只要有一個命令返回假(命令返回值 $? == 1),后面的命令就不會被執行。
示例 1
malihou@ubuntu:~$ cp ~/Desktop/1.txt ~/1.txt && rm ~/Desktop/1.txt && echo “success”
示例 1 中的命令首先從 ~/Desktop 目錄復制 1.txt 文件到 ~ 目錄;執行成功后,使用 rm 刪除源文件;如果刪除成功則輸出提示信息。
||運算符:
command1 || command2
||則與&&相反。如果||左邊的命令(命令1)未執行成功,那么就執行||右邊的命令(命令2);或者換句話說,“如果這個命令執行失敗了||那么就執行這個命令。
1 命令之間使用 || 連接,實現邏輯或的功能。
2 只有在 || 左邊的命令返回假(命令返回值 $? == 1),|| 右邊的命令才會被執行。這和 c 語言中的邏輯或語法功能相同,即實現短路邏輯或操作。
3 只要有一個命令返回真(命令返回值 $? == 0),后面的命令就不會被執行。
示例 2
malihou@ubuntu:~$ rm ~/Desktop/1.txt || echo “fail”
在示例 2 中,如果 ~/Desktop 目錄下不存在文件 1.txt,將輸出提示信息。
示例 3
malihou@ubuntu:~$ rm ~/Desktop/1.txt && echo “success” || echo “fail”
在示例 3 中,如果 ~/Desktop 目錄下存在文件 1.txt,將輸出 success 提示信息;否則輸出 fail 提示信息。
如果希望把幾個命令合在一起執行, s h e l l提供了兩種方法。既可以在當前s h e l l也可以在子s h e l l中執行一組命令。
()運算符:
為了在當前shell中執行一組命令,可以用命令分隔符(即”,”)隔開每一個命令,并把所有的命令用圓括號()括起來。
它的一般形式為:
? ? ? ? ( 命令;命令;命令… )
1 一條命令需要獨占一個物理行,如果需要將多條命令放在同一行,命令之間使用命令分隔符(;)分隔。執行的效果等同于多個獨立的命令單獨執行的效果。
2 () 表示在當前 shell 中將多個命令作為一個整體執行。需要注意的是,使用 () 括起來的命令在執行前面都不會切換當前工作目錄,也就是說命令組合都是在當前工作目錄下被執行的,盡管命令中有切換目錄的命令。
3 命令組合常和命令執行控制結合起來使用。
示例 4
malihou@ubuntu:~$ rm ~/Desktop/1.txt || (cd ~/Desktop/;ls -a;echo “fail”)
在示例 4 中,如果目錄 ~/Desktop 下不存在文件 1.txt,則執行命令組合。
{}運算符:
如果使用{}來代替(),那么相應的命令將在子shell而不是當前shell中作為一個整體被執行,只有在{}中所有命令的輸出作為一個整體被重定向時,其中的命令才被放到子shell中執行,否則在當前shell執行。
它的一般形式為:
? ? ? { 命令;命令;命令… }
(注意:在使用{}時,{}與命令之間必須使用一個空格)
測試:
~$ A=1;echo $A;{ A=2; };echo $A
1
2
~$ A=1;echo $A;( A=2; );echo $A
1
原文地址 :https://blog.csdn.net/a627088424/article/details/20360107
本文來自投稿,不代表Linux運維部落立場,如若轉載,請注明出處:http://www.www58058.com/96935