shell 基本計(jì)算、邏輯運(yùn)算、位運(yùn)算詳解
更新時(shí)間:2012年09月02日 22:52:35 作者:
Shell 提供大量的基本運(yùn)算操作,在腳本中非常有用。Shell 對(duì)您提供的算術(shù)表達(dá)式求值,執(zhí)行運(yùn)算展開(kāi)式,此時(shí)使用得出的結(jié)果替換表達(dá)式
以下面的格式提供運(yùn)算表達(dá)式:$(( expression ))
$ echo $((5*(3+3)))
30
$ result = $(($myvar-10))
shell提供方便的數(shù)之間的進(jìn)制轉(zhuǎn)換:
$ echo $((013))#八進(jìn)制
$ echo $((0xA4))#十六進(jìn)制
還可以使用以下格式指定 2 到 64 之間的任意進(jìn)制:
$((BASE#NUMBER))
echo $((8#377))
echo $((16#D8))
在 Shell 中進(jìn)行進(jìn)制轉(zhuǎn)換的另一個(gè)訣竅是使用 bc, 它是一種任意精度運(yùn)算語(yǔ)言,大多數(shù) UNIX 安裝程序都提供。因?yàn)樗试S您指定輸出進(jìn)制,所以當(dāng)您需要以十進(jìn)制以外的進(jìn)制輸出時(shí),這是一種很好的技術(shù)。
bc 的特殊變量 ibase 和 obase 分別包含用于輸入和輸出的進(jìn)制的值。缺省情況下,都被設(shè)置為 10。要執(zhí)行進(jìn)制轉(zhuǎn)換,需要改變其中的一個(gè)或兩個(gè)值,然后提供一個(gè)數(shù)字。
$ echo 'obase=16; 47' | bc
2F
$ echo 'obase=10; ibase=16; A03' | bc
2563
了解了這些基本特性,下邊再看看邏輯運(yùn)算符和邏輯表達(dá)式,基本的 + – * / % 不再贅述。
一、邏輯運(yùn)算符
二、邏輯表達(dá)式
test 命令
使用方法:test EXPRESSION
如:
[root@localhost ~]# test 1 = 1 && echo ‘ok'
ok
[root@localhost ~]# test -d /etc/ && echo ‘ok'
ok
[root@localhost ~]# test 1 -eq 1 && echo ‘ok'
ok
[root@localhost ~]# if test 1 = 1 ; then echo ‘ok'; fi
ok
注意:所有字符 與邏輯運(yùn)算符直接用“空格”分開(kāi),不能連到一起。
精簡(jiǎn)表達(dá)式
[] 表達(dá)式
[root@localhost ~]# [ 1 -eq 1 ] && echo ‘ok'
ok
[root@localhost ~]# [ 2 < 1 ] && echo ‘ok'
-bash: 2: No such file or directory
[root@localhost ~]# [ 2 \< 1 ] && echo ‘ok'
[root@localhost ~]# [ 2 -gt 1 -a 3 -lt 4 ] && echo ‘ok'
ok
[root@localhost ~]# [ 2 -gt 1 && 3 -lt 4 ] && echo ‘ok'
-bash: [: missing `]‘
注意:在[] 表達(dá)式中,常見(jiàn)的>,<需要加轉(zhuǎn)義字符,表示字符串大小比較,以acill碼 位置作為比較。 不直接支持<>運(yùn)算符,還有邏輯運(yùn)算符|| && 它需要用-a[and] –o[or]表示
[[]] 表達(dá)式
[root@localhost ~]# [ 1 -eq 1 ] && echo ‘ok'
ok[root@localhost ~]$ [[ 2 < 3 ]] && echo ‘ok'
ok
[root@localhost ~]$ [[ 2 < 3 && 4 > 5 ]] && echo ‘ok'
ok
注意:[[]] 運(yùn)算符只是[]運(yùn)算符的擴(kuò)充。能夠支持<,>符號(hào)運(yùn)算不需要轉(zhuǎn)義符,它還是以字符串比較大小。里面支持邏輯運(yùn)算符:|| &&
三、性能比較
bash的條件表達(dá)式中有三個(gè)幾乎等效的符號(hào)和命令:test,[]和[[]]。通常,大家習(xí)慣用if [];then這樣的形式。而[[]]的出現(xiàn),根據(jù)ABS所說(shuō),是為了兼容><之類的運(yùn)算符。以下是比較它們性能,發(fā)現(xiàn)[[]]是最快的。
$ time (for m in {1..100000}; do test -d .;done;)
real 0m0.658s
user 0m0.558s
sys 0m0.100s
$ time (for m in {1..100000}; do [ -d . ];done;)
real 0m0.609s
user 0m0.524s
sys 0m0.085s
$ time (for m in {1..100000}; do [[ -d . ]];done;)
real 0m0.311s
user 0m0.275s
sys 0m0.036s
不考慮對(duì)低版本bash和對(duì)sh的兼容的情況下,用[[]]是兼容性強(qiáng),而且性能比較快,在做條件運(yùn)算時(shí)候,可以使用該運(yùn)算符。
四、按位操作運(yùn)算符
注: 對(duì)于按位非,若求“~a”則結(jié)果為-(a+1)舉一個(gè)詳細(xì)例子:求“~8”分析由于計(jì)算機(jī)通常
用補(bǔ)碼進(jìn)行符號(hào)運(yùn)算,[[x]補(bǔ)]補(bǔ)=[x]所以
則8的二進(jìn)制為00001000 求非為11110111
求反碼為1001000求補(bǔ)碼為1001001所以最后的結(jié)果為1001001,~8 即為-9。
$ echo $((5*(3+3)))
30
$ result = $(($myvar-10))
shell提供方便的數(shù)之間的進(jìn)制轉(zhuǎn)換:
$ echo $((013))#八進(jìn)制
$ echo $((0xA4))#十六進(jìn)制
還可以使用以下格式指定 2 到 64 之間的任意進(jìn)制:
$((BASE#NUMBER))
echo $((8#377))
echo $((16#D8))
在 Shell 中進(jìn)行進(jìn)制轉(zhuǎn)換的另一個(gè)訣竅是使用 bc, 它是一種任意精度運(yùn)算語(yǔ)言,大多數(shù) UNIX 安裝程序都提供。因?yàn)樗试S您指定輸出進(jìn)制,所以當(dāng)您需要以十進(jìn)制以外的進(jìn)制輸出時(shí),這是一種很好的技術(shù)。
bc 的特殊變量 ibase 和 obase 分別包含用于輸入和輸出的進(jìn)制的值。缺省情況下,都被設(shè)置為 10。要執(zhí)行進(jìn)制轉(zhuǎn)換,需要改變其中的一個(gè)或兩個(gè)值,然后提供一個(gè)數(shù)字。
復(fù)制代碼 代碼如下:
$ echo 'obase=16; 47' | bc
2F
$ echo 'obase=10; ibase=16; A03' | bc
2563
了解了這些基本特性,下邊再看看邏輯運(yùn)算符和邏輯表達(dá)式,基本的 + – * / % 不再贅述。
一、邏輯運(yùn)算符
| 邏輯卷標(biāo) | 表示意思 |
| 1. | 關(guān)于檔案與目錄的偵測(cè)邏輯卷標(biāo)! |
| -f | 常用!偵測(cè)『檔案』是否存在 eg: if [ -f filename ] |
| -d | 常用!偵測(cè)『目錄』是否存在 |
| -b | 偵測(cè)是否為一個(gè)『 block 檔案』 |
| -c | 偵測(cè)是否為一個(gè)『 character 檔案』 |
| -S | 偵測(cè)是否為一個(gè)『 socket 標(biāo)簽檔案』 |
| -L | 偵測(cè)是否為一個(gè)『 symbolic link 的檔案』 |
| -e | 偵測(cè)『某個(gè)東西』是否存在! |
| 2. | 關(guān)于程序的邏輯卷標(biāo)! |
| -G | 偵測(cè)是否由 GID 所執(zhí)行的程序所擁有 |
| -O | 偵測(cè)是否由 UID 所執(zhí)行的程序所擁有 |
| -p | 偵測(cè)是否為程序間傳送信息的 name pipe 或是 FIFO (老實(shí)說(shuō),這個(gè)不太懂?。?/TD> |
| 3. | 關(guān)于檔案的屬性偵測(cè)! |
| -r | 偵測(cè)是否為可讀的屬性 |
| -w | 偵測(cè)是否為可以寫入的屬性 |
| -x | 偵測(cè)是否為可執(zhí)行的屬性 |
| -s | 偵測(cè)是否為『非空白檔案』 |
| -u | 偵測(cè)是否具有『 SUID 』的屬性 |
| -g | 偵測(cè)是否具有『 SGID 』的屬性 |
| -k | 偵測(cè)是否具有『 sticky bit 』的屬性 |
| 4. | 兩個(gè)檔案之間的判斷與比較 ;例如[ test file1 -nt file2 ] |
| -nt | 第一個(gè)檔案比第二個(gè)檔案新 |
| -ot | 第一個(gè)檔案比第二個(gè)檔案舊 |
| -ef | 第一個(gè)檔案與第二個(gè)檔案為同一個(gè)檔案( link 之類的檔案) |
| 5. | 邏輯的『和(and)』『或(or)』 |
| && | 邏輯的 AND 的意思 |
| || | 邏輯的 OR 的意思 |
| 運(yùn)算符號(hào) | 代表意義 |
| = | 等于 應(yīng)用于:整型或字符串比較 如果在[] 中,只能是字符串 |
| != | 不等于 應(yīng)用于:整型或字符串比較 如果在[] 中,只能是字符串 |
| < | 小于 應(yīng)用于:整型比較 在[] 中,不能使用 表示字符串 |
| > | 大于 應(yīng)用于:整型比較 在[] 中,不能使用 表示字符串 |
| -eq | 等于 應(yīng)用于:整型比較 |
| -ne | 不等于 應(yīng)用于:整型比較 |
| -lt | 小于 應(yīng)用于:整型比較 |
| -gt | 大于 應(yīng)用于:整型比較 |
| -le | 小于或等于 應(yīng)用于:整型比較 |
| -ge | 大于或等于 應(yīng)用于:整型比較 |
| -a | 雙方都成立(and) 邏輯表達(dá)式 –a 邏輯表達(dá)式 |
| -o | 單方成立(or) 邏輯表達(dá)式 –o 邏輯表達(dá)式 |
| -z | 空字符串 |
| -n | 非空字符串 |
二、邏輯表達(dá)式
test 命令
使用方法:test EXPRESSION
如:
[root@localhost ~]# test 1 = 1 && echo ‘ok'
ok
[root@localhost ~]# test -d /etc/ && echo ‘ok'
ok
[root@localhost ~]# test 1 -eq 1 && echo ‘ok'
ok
[root@localhost ~]# if test 1 = 1 ; then echo ‘ok'; fi
ok
注意:所有字符 與邏輯運(yùn)算符直接用“空格”分開(kāi),不能連到一起。
精簡(jiǎn)表達(dá)式
[] 表達(dá)式
[root@localhost ~]# [ 1 -eq 1 ] && echo ‘ok'
ok
[root@localhost ~]# [ 2 < 1 ] && echo ‘ok'
-bash: 2: No such file or directory
[root@localhost ~]# [ 2 \< 1 ] && echo ‘ok'
[root@localhost ~]# [ 2 -gt 1 -a 3 -lt 4 ] && echo ‘ok'
ok
[root@localhost ~]# [ 2 -gt 1 && 3 -lt 4 ] && echo ‘ok'
-bash: [: missing `]‘
注意:在[] 表達(dá)式中,常見(jiàn)的>,<需要加轉(zhuǎn)義字符,表示字符串大小比較,以acill碼 位置作為比較。 不直接支持<>運(yùn)算符,還有邏輯運(yùn)算符|| && 它需要用-a[and] –o[or]表示
[[]] 表達(dá)式
[root@localhost ~]# [ 1 -eq 1 ] && echo ‘ok'
ok[root@localhost ~]$ [[ 2 < 3 ]] && echo ‘ok'
ok
[root@localhost ~]$ [[ 2 < 3 && 4 > 5 ]] && echo ‘ok'
ok
注意:[[]] 運(yùn)算符只是[]運(yùn)算符的擴(kuò)充。能夠支持<,>符號(hào)運(yùn)算不需要轉(zhuǎn)義符,它還是以字符串比較大小。里面支持邏輯運(yùn)算符:|| &&
三、性能比較
bash的條件表達(dá)式中有三個(gè)幾乎等效的符號(hào)和命令:test,[]和[[]]。通常,大家習(xí)慣用if [];then這樣的形式。而[[]]的出現(xiàn),根據(jù)ABS所說(shuō),是為了兼容><之類的運(yùn)算符。以下是比較它們性能,發(fā)現(xiàn)[[]]是最快的。
$ time (for m in {1..100000}; do test -d .;done;)
real 0m0.658s
user 0m0.558s
sys 0m0.100s
$ time (for m in {1..100000}; do [ -d . ];done;)
real 0m0.609s
user 0m0.524s
sys 0m0.085s
$ time (for m in {1..100000}; do [[ -d . ]];done;)
real 0m0.311s
user 0m0.275s
sys 0m0.036s
不考慮對(duì)低版本bash和對(duì)sh的兼容的情況下,用[[]]是兼容性強(qiáng),而且性能比較快,在做條件運(yùn)算時(shí)候,可以使用該運(yùn)算符。
四、按位操作運(yùn)算符
| 運(yùn)算符 | 名稱 | 舉例 | 解釋value的值 |
| << | 左移 | value=4>>2 | 4左移2位,value值為16 |
| >> | 右移 | value=8<<2 | 8右移2位,value值為2 |
| & | 按位與 | value=8&&4 | 8按位與4,value值為0 |
| | | 按位或 | value=8|4 | 8按位或4,value值為12 |
| ~ | 按位非 | value=~8 | 按位非8,value值為-9 |
| ^ | 按位異或 | value=10^3 | 10按位異或3,value值為9 |
注: 對(duì)于按位非,若求“~a”則結(jié)果為-(a+1)舉一個(gè)詳細(xì)例子:求“~8”分析由于計(jì)算機(jī)通常
用補(bǔ)碼進(jìn)行符號(hào)運(yùn)算,[[x]補(bǔ)]補(bǔ)=[x]所以
則8的二進(jìn)制為00001000 求非為11110111
求反碼為1001000求補(bǔ)碼為1001001所以最后的結(jié)果為1001001,~8 即為-9。
您可能感興趣的文章:
- C# 位運(yùn)算符整理
- 通過(guò)SQL Server的位運(yùn)算功能巧妙解決多選查詢方法
- Erlang的運(yùn)算符(比較運(yùn)算符,數(shù)值運(yùn)算符,移位運(yùn)算符,邏輯運(yùn)算符)
- c語(yǔ)言中用位運(yùn)算實(shí)現(xiàn)加法技巧介紹
- Java中位運(yùn)算(移位、位與、或、異或、非) 的簡(jiǎn)單實(shí)例
- C#枚舉中的位運(yùn)算權(quán)限分配淺談
- C語(yǔ)言位運(yùn)算符:與、或、異或、取反、左移與右移詳細(xì)介紹
- 詳細(xì)介紹Python語(yǔ)言中的按位運(yùn)算符
- JavaScript按位運(yùn)算符的應(yīng)用簡(jiǎn)析
- 圖文詳解C語(yǔ)言位運(yùn)算基礎(chǔ)知識(shí)
相關(guān)文章
Shell內(nèi)置命令教程之a(chǎn)lias和echo
我們?nèi)粘J褂胹hell輸入命令得到結(jié)果的方式是交互式的方式,而shell腳本使用的是非交互式方式,shell提供了alias功能來(lái)簡(jiǎn)化我們的日常操作,下面這篇文章主要給大家介紹了關(guān)于Shell內(nèi)置命令教程之a(chǎn)lias和echo的相關(guān)資料,需要的朋友可以參考下2022-03-03
3000字掃盲shell基礎(chǔ)知識(shí)(新手必備)
這篇文章主要介紹了3000字掃盲shell基礎(chǔ)知識(shí),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2020-06-06
shell向文件中添加新內(nèi)容的實(shí)現(xiàn)方法
Shell腳本是一種為shell編寫的腳本程序,下面這篇文章主要給大家介紹了關(guān)于shell向文件中添加新內(nèi)容的實(shí)現(xiàn)方法,需要的朋友可以參考下2023-06-06
Shell腳本實(shí)現(xiàn)自動(dòng)修改IP地址
這篇文章主要介紹了Shell腳本實(shí)現(xiàn)自動(dòng)修改IP地址,本文直接給出實(shí)現(xiàn)代碼,并在代碼中標(biāo)注大量注釋,需要的朋友可以參考下2014-10-10
兩個(gè)備份數(shù)據(jù)庫(kù)的shell腳本
這篇文章主要是分享兩個(gè)備份數(shù)據(jù)庫(kù)的shell腳本,需要的朋友可以參考下,功能略有不同2013-02-02
shell腳本無(wú)密碼登錄 expect的使用方法詳解
這篇文章主要介紹了shell腳本無(wú)密碼登錄 expect的使用方法詳解的相關(guān)資料,希望通過(guò)本文能幫助到大家,需要的朋友可以參考下2017-10-10
win10下如何運(yùn)行.sh文件的實(shí)現(xiàn)步驟
這篇文章主要介紹了win10下如何運(yùn)行.sh文件的實(shí)現(xiàn)步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09

