溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

shell中基本計(jì)算、邏輯運(yùn)算、位運(yùn)算的示例分析

發(fā)布時(shí)間:2021-10-14 15:59:13 來源:億速云 閱讀:142 作者:小新 欄目:開發(fā)技術(shù)

這篇文章給大家分享的是有關(guān)shell中基本計(jì)算、邏輯運(yùn)算、位運(yùn)算的示例分析的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。

以下面的格式提供運(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)算語言,大多數(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)算符

邏輯卷標(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í)說,這個(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)算符直接用“空格”分開,不能連到一起。

精簡表達(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á)式中,常見的>,<需要加轉(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所說,是為了兼容><之類的運(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>>24左移2位,value值為16
>>右移value=8<<28右移2位,value值為2
&按位與value=8&&48按位與4,value值為0
|按位或value=8|48按位或4,value值為12
~按位非value=~8按位非8,value值為-9
^按位異或value=10^310按位異或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。

感謝各位的閱讀!關(guān)于“shell中基本計(jì)算、邏輯運(yùn)算、位運(yùn)算的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI