這兩個命令分別用來退出循環(huán),或跳到循環(huán)體的其他地方。使用 while 與 break,等待用戶登錄。
bash 代碼:
printf “Enter username:”
read user
while true
do
if who | grep “$user” >/dev/null
then
break;
fi
sleep 30
done
等待特定用戶,每 30 秒確認(rèn)一次
true 命令什么事也不必做,只是成功的退出。這用于編寫無限循環(huán),即會永久的執(zhí)行循環(huán)。在編寫無限循環(huán)時,必須放置一個退出條件在循環(huán)體內(nèi),正如這里所作的。另有一個 false 命令和它有點相似,只是很少的用到,也不做人和事,僅表示不成功的狀態(tài).false 命令常見于無線的 until false..循環(huán)中。
continue 命令則用于提早的開始下一段重復(fù)動作,也就是在到大循環(huán)體的底部之前。
break 與 continue 命令都可以接受可選的數(shù)值參數(shù),可分別用來之處要中斷 (break) 或繼續(xù)多少個被包含的循環(huán) (如果循環(huán)技術(shù)需要的是一個在運行時可被計算的表達(dá)式時,可以使用 $((...)) )。
案例:
while condition1 // 外循環(huán)
do...
while condition2 // 內(nèi)循環(huán)
do..
break; 外循環(huán)的終端
done
done
break 與 continue 特別具備終端或繼續(xù)多個循環(huán)層的能力。從而以簡潔的形式彌補(bǔ)了 shell 語言里缺乏 goto 關(guān)鍵字的不足。
使用 continue 的案例:
\#!/bin/bash
limit=19
echo "printing Number 1 throught 20"
a=0
while [$a -le"$limit"]
do
let a++
#let a+=1
#a=$(($a+1))
if ["$a" -eq 3] || ["$a" -eq 11]
then
continue
fi
echo -n "$a"
done
輸出結(jié)果:
printing Number 1 throught 20
1 2 4 5 6 7 8 9 10 12 13 14 15 16 17 18 19 20
由此可見 continue 的作用是結(jié)束本次循環(huán),執(zhí)行下一次循環(huán)
使用 break 的案例:
\#!/bin/bash
limit=19
echo "printing Number 1 throught 20"
a=0
while [$a -le"$limit"]
do
let a++
#let a+=1
#a=$(($a+1))
if ["$a" -eq 3] || ["$a" -eq 11]
then
break
fi
echo -n "$a"
done
輸出結(jié)果:
printing Number 1 throught 20
1 2
由此可見,break 的作用是退出當(dāng)前循環(huán)。
shift
我們知道,對于位置變量或命令行參數(shù),其個數(shù)必須是確定的,或者當(dāng) Shell 程序不知道其個數(shù)時,可以把所有參數(shù)一起賦值給變量 $*。若用戶要求 Shell 在不知道位置變量個數(shù)的情況下,還能逐個的把參數(shù)一一處理,也就是在 $1 后為 $2,在 $2 后面為 $3 等。在 shift 命令執(zhí)行前變量 $1 的值在 shift 命令執(zhí)行后就不可用了。
案例:
\#!/bin/bash
until [$# -eq 0]
do
echo " 第一個參數(shù)為:$1 參數(shù)個數(shù)為:$#"
shift
done
執(zhí)行命令:./shift.sh 1 2 3 4
輸出為:
第一個參數(shù)為:1 參數(shù)個數(shù)為:4
第一個參數(shù)為:2 參數(shù)個數(shù)為:3
第一個參數(shù)為:3 參數(shù)個數(shù)為:2
第一個參數(shù)為:4 參數(shù)個數(shù)為:1
分析:
第一個參數(shù) $1
第二個參數(shù) $2
第 n 個參數(shù) $n
所有參數(shù) $@ 或 $*
參數(shù)個數(shù) $#
案例:
bash 代碼:
until [-z"$1"] # Until all parameters used up
do
echo "$@"
shift
done
命令:./shift1.sh 1 2 3 4 5 6 7 8 9 10
輸出:
1 2 3 4 5 6 7 8 9 10
2 3 4 5 6 7 8 9 10
3 4 5 6 7 8 9 10
4 5 6 7 8 9 10
5 6 7 8 9 10
6 7 8 9 10
7 8 9 10
8 9 10
9 10
10
getopts 命令
語法:
getopts option_spec variable [arguments...]
現(xiàn)在來看一個簡單的例子:
\#!/bin/bash
echo $*
while getopts ":a:bc:" opt
do
case $opt in
a)
echo $OPTARG
echo $OPTIND
;;
b)
echo "b $OPTIND"
;;
c)
echo "c $OPTIND"
;;
?)
echo "error"
exit 1
esac
done
echo $OPTIND
shift $(($OPTIND-1))
echo $0
echo $*
如果執(zhí)行命令:./getopts.sh -a 11 -b -c 6
結(jié)果為:
-a 11 -b -c 6
11
3
b 4
c 6
6
./getopts.sh
看分析:
getopts 后面的字符串就是可以使用的選項列表,每個字母代表一個選項,后面帶:的意味著選項除了定義本身之外,還會帶上一個參數(shù)作為選項的值,比如 a:在實際的使用中就會對應(yīng) -a 11,選項的值就是 11;getopts 字符串中沒有跟隨:的是開關(guān)型選項,不需要再指定值,相當(dāng)于 true/false,只要帶了這個參數(shù)就是 true。如果命令行中包含了沒有在 getopts 列表中的選項,會有警告信息,如果在整個 getopts 字符串前面也加上個:,就能消除警告信息了。使用 getopts 識別出各個選項之后,就可以配合 case 來進(jìn)行相應(yīng)的操作了。optarg 這個變變,getopts 修改了這個變量。這里變量 $optarg 存儲相應(yīng)選項的參數(shù),而 $optind 總是存儲原始 $* 中下一個要處理的元素 (不是參數(shù),而是選項,此處值得的是 a,b,c 這三個選線,而不是那些數(shù)字,當(dāng)然數(shù)字也是會占有位置的) 位置。
while getopts ":a:bc:" opt # 第一個冒號表示忽略錯誤;字符后面的冒號表示該選項必須有自己的參數(shù)。
使用 getopts 處理參數(shù)雖然是方便,但仍然有兩個小小的局限:
-d val,而不能是中間沒有空格的 -dval。getopts 是從命令行前面開始處理,遇到非 - 開頭的參數(shù),或者選項參數(shù)結(jié)束標(biāo)記 -- 就中止了,如果中間遇到非選項的命令行參數(shù),后面的選項參數(shù)就都取不到了。debug 之類的選項案例:
\#!/bin/bash
while getopts "ab:cd:" opt
do
case $opt in
a)
echo $OPTIND
;;
b)
echo $OPTIND
echo $OPTARG
;;
c)
echo $OPTIND
;;
d)
echo $OPTIND
echo $OPTARG
esac
done
shift $(($OPTIND-1))
使用命令:./getopts1.sh -a -b foo -c -d haha
得到結(jié)果:
2
4
foo
5
7
haha
最后使用 shift $(($OPTIND-1)) 的作用是:通過 shift $(($OPTIND - 1)) 的處理,$* 中就只保留了除去選項內(nèi)容的參數(shù),可以在其后進(jìn)行正常的 shell 編程處理了。 貌似不用也可以。
如果出現(xiàn)這種情況:
getopts “:ab:c” 第一個冒號代表的含義是:第一個冒號表示忽略錯誤,即當(dāng)出現(xiàn)沒有的選項是會忽略;字符后面的冒號表示該選項必須有自己的參數(shù)。