和其餘高級程序設計語言同樣,Shell提供了用來控制程序執行流程的命令,包括條件分支和循環結構,用戶能夠用這些命令建立很是複雜的程序。 express
與傳統語言不一樣的是,Shell用於指定條件值的不是布爾運算式,而是命令和字串。 bash
1.測試命令 測試
test命令用於檢查某個條件是否成立,它能夠進行數值、字符和文件3個方面的測試,其測試符和相應的功能分別以下。 命令行
(1)數值測試: 設計
-eq 等於則爲真。 內存
-ne 不等於則爲真。 it
-gt 大於則爲真。 io
-ge 大於等於則爲真。 for循環
-lt 小於則爲真。 程序設計
-le 小於等於則爲真。
(2)字串測試:
= 等於則爲真。
!= 不相等則爲真。
-z字串 字串長度僞則爲真。
-n字串 字串長度不僞則爲真。
(3)文件測試:
-e文件名 若是文件存在則爲真。
-r文件名 若是文件存在且可讀則爲真。
-w文件名 若是文件存在且可寫則爲真。
-x文件名 若是文件存在且可執行則爲真。
-s文件名 若是文件存在且至少有一個字符則爲真。
-d文件名 若是文件存在且爲目錄則爲真。
-f文件名 若是文件存在且爲普通文件則爲真。
-c文件名 若是文件存在且爲字符型特殊文件則爲真。
-b文件名 若是文件存在且爲塊特殊文件則爲真。
另外,Linux還提供了與(!)、或(-o)、非(-a)三個邏輯操做符,用於將測試條件鏈接起來,其優先順序爲:!最高,-a次之,-o最低。
同時,bash也能完成簡單的算術運算,格式以下:
$[expression]
例如:
var1=2
var2=$[var1*10+1]
則var2的值爲21。
2.if條件語句
Shell程序中的條件分支是經過if條件語句來實現的,其通常格式爲:
if 條件命令串
then
條件爲真時的命令串
else
條件爲假時的命令串
fi
3.for循環
for循環對一個變量的可能的值都執行一個命令序列。賦給變量的幾個數值既能夠在程序內以數值列表的形式提供,也能夠在程序之外以位置參數的形式提供。for循環的通常格式爲:
for變量名 [in數值列表]
do
若干個命令行
done
變量名能夠是用戶選擇的任何字串,若是變量名是var,則在in以後給出的數值將順序替換循環命令列表中的$var。若是省略了in,則變量var的取值將是位置參數。對變量的每個可能的賦值都將執行do和done之間的命令列表。
4.while和until循環
while和until命令都是用命令的返回狀態值來控制循環的。While循環的通常格式爲:
while
若干個命令行1
do
若干個命令行2
done
只要while的「若干個命令行1」中最後一個命令的返回狀態爲真,while循環就繼續執行do...done之間的「若干個命令行2」。
until命令是另外一種循環結構,它和while命令類似,其格式以下:
until
若干個命令行1
do
若干個命令行2
done
until循環和while循環的區別在於:while循環在條件爲真時繼續執行循環,而until則是在條件爲假時繼續執行循環。
Shell還提供了true和false兩條命令用於建立無限循環結構,它們的返回狀態分別是總爲0或總爲非0。
9.信號
trap命令用於在Shell程序中捕捉信號,以後能夠有3種反應方式:
(1)執行一段程序來處理這一信號。
(2)接受信號的默認操做。
(3)忽視這一信號。
trap對上面3種方式提供了3種基本形式:
第一種形式的trap命令在Shell接收到與signal list清單中數值相同的信號時,將執行雙引號中的命令串。
trap 'commands' signal-list
trap "commands" signal-list
爲了恢復信號的默認操做,使用第二種形式的trap命令:
trap signal-list
第三種形式的trap命令容許忽略信號:
trap " " signal-list
注意:
(1)對信號11(段違例)不能捕捉,由於Shell自己須要捕捉該信號去進行內存的轉儲。
(2)在trap中能夠定義對信號0的處理(實際上沒有這個信號),Shell程序在其終止(如執行exit語句)時發出該信號。
(3)在捕捉到signal-list中指定的信號並執行完相應的命令以後,若是這些命令沒有將Shell程序終止的話,Shell程序將繼續執行收到信號時所執行的命令後面的命令,這樣將很容易致使Shell程序沒法終止。
另外,在trap語句中,單引號和雙引號是不一樣的。當Shell程序第一次碰到trap語句時,將把commands中的命令掃描一遍。此時若 commands是用單引號括起來的話,那麼Shell不會對commands中的變量和命令進行替換,不然commands中的變量和命令將用當時具體 的值來替換。