Unix系統中常見的shell有:sh、csh、ksh、tcsh、bash
使用命令: vim /etc/shells 可以查看當前系統支持的bash
shell執行腳本是一門解釋性語言、批量化處理語言,大大的節省了工作成本
shell腳本第一行必須以 #!開頭,它表示該腳本使用後面的解釋器解釋執行。
舉個栗子:
//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開始執行,而這個文本文件被當作命令行參數傳給解釋器。因此,執行上述腳本相當於執行程序!
輸入命令執行shell腳本後:
注意:像export、cd、env、set 這些內置命令,在鍵入命令行後,交互式進程不會創建子進程,而是調用bash內部的函數執行這些命令,改變的是交互式進程。
如果在命令行下,將多個命令用括號括起來,並用分號隔開來執行,交互式進程依然會創建一個子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-1的結果賦給SUB,並顯示本地變量SUB
SUB=$((2-1)) echo $SUB
3.單引號和雙引號
Shell腳本中的單引號和雙引號一樣都是字符串的界定符,單引號用於保持引號內所有字符的字面值,而雙引號有些情況則特殊。如果字符串中有特殊字符需要處理時就用雙引號。
注:單引號標注的字符中不能再出現單引號。
舉個栗子:
#!/bin/bash echo '\\' echo "\\" echo '`date`' echo "`date`"
http://xxxxxx/Linuxjc/1148877.html TechArticle