Unix系統中常見的shell有:sh、csh、ksh、tcsh、bashshell
使用命令: vim /etc/shells 能夠查看當前系統支持的bash編程
shell執行腳本是一門解釋性語言、批量化處理語言,大大的節省了工做成本vim
shell腳本第一行必須以 #!開頭,它表示該腳本使用後面的解釋器解釋執行。bash
舉個栗子:編程語言
//script.sh 注:這是一個文本文件函數
#!/bin/bash echo "this is a test" ls ls -l echo "there are all files"
執行方式:學習
//第一種執行方式: [admin@localhost Shell]$ chmod +x script.sh [admin@localhost Shell]$ ./script.sh //第二種執行方式: [admin@localhost Shell]$ /bin/bash script.sh
執行過程:測試
Shell會fork一個子進程並調用exec執行./script.sh這個程序,exec系統調用應該把子進程的代碼段替換成./script.sh程序的代碼段,並從它的_start開始執行。然而script.sh是個文本文件,根 本沒有代碼段和_start函數,怎麼辦呢?其實exec還有另一種機制,若是要執行的是一個文本文件,而且第一行 指定了解釋器,則用解釋器程序的代碼段替換當前進程,而且從解釋器 的_start開始執行,而這個文本文件被看成命令行參數傳給解釋器。所以,執行上述腳本至關於執行程序!this
輸入命令執行shell腳本後:spa
注意:像export、cd、env、set 這些內置命令,在鍵入命令行後,交互式進程不會建立子進程,而是調用bash內部的函數執行這些命令,改變的是交互式進程。
若是在命令行下,將多個命令用括號括起來,並用分號隔開來執行,交互式進程依然會建立一個子shell執行括號中的命令:
若是不加括號則是另外一種狀況,cd .. 命令會直接在交互式shell下執行:
. 或者 source這兩個命令是Shell的內建命令,這種方式不會建立子Shell,而是直接在交互式Shell下逐行 執行腳本中的命令。
例證:
script.sh
#!/bin/bash ls echo "#################" cd .. ls
shell變量不須要進行任何聲明,直接定義便可,由於shell變量的值實際上都是字符串(對於沒有定義的變量默認是一個空串)。定義的時候shell變量由大寫字母加下劃線組成,而且定義的時候等號兩邊不能存在空格,不然會被認爲是命令!
shell變量的種類:
利用printenv能夠顯示當前shell進程的環境變量;利用set命令能夠顯示當前shell進程中的定義的全部變量(包括環境變量和本地變量)和函數。
一個shell變量定義後僅存在於當前Shell進程,是一個本地變量。用export命令能夠把本地變量導出爲環境變量。用unset命令能夠刪除已定義的環境變量或本地變量。
例如:
//分步 先定義後導出 COUNT=5 export COUNT //一步完成定義和導出環境變量 export COUNT=5 //刪除已經定義的環境變量 unset COUNT
變量引用:
引用shell變量要用到$符號,加{}能夠防止歧義。
例如:
COUNT=5 echo $COUNT echo ${COUNT}911
1.常見的通配符:
* : 匹配0個或多個任意字符
? : 匹配一個任意字符
[若干字符] : 匹配方括號中任意一個字符的一次出現
2.命令代換:
反引號`` 或者 $()
script.sh :
shell會先執行反引號或$()中的命令,將結果代換到當前命令行中!
反引號和$()的區別:
反引號自己就對\進行了轉義,保留了自己意思,若是咱們想在反引號中起到\的特殊意義,咱們必須使用2個\來進行表示。
反引號中: \\ = \
$()中:\ = \
注意:反引號是老的用法,$()是新的用法,無論是在學習測試中,仍是在實際工做中,$()的用法都是被推薦的。
算數代換:$(())
例如:將2-1的結果賦給SUB,並顯示本地變量SUB
SUB=$((2-1)) echo $SUB
3.單引號和雙引號
Shell腳本中的單引號和雙引號同樣都是字符串的界定符,單引號用於保持引號內全部字符的字面值,而雙引號有些狀況則特殊。若是字符串中有特殊字符須要處理時就用雙引號。
注:單引號標註的字符中不能再出現單引號。
舉個栗子:
#!/bin/bash echo '\\' echo "\\" echo '`date`' echo "`date`"