這篇文章主要介紹“如何理解linux shell邏輯運(yùn)算符、邏輯表達(dá)式”,在日常操作中,相信很多人在如何理解linux shell邏輯運(yùn)算符、邏輯表達(dá)式問(wèn)題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”如何理解linux shell邏輯運(yùn)算符、邏輯表達(dá)式”的疑惑有所幫助!接下來(lái),請(qǐng)跟著小編一起來(lái)學(xué)習(xí)吧!
創(chuàng)新互聯(lián)于2013年創(chuàng)立,是專(zhuān)業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目成都做網(wǎng)站、網(wǎng)站制作網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元沙依巴克做網(wǎng)站,已為上家服務(wù),為沙依巴克各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話(huà):13518219792一、邏輯運(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è)是否為可以寫(xiě)入的屬性 |
-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 之類(lèi)的檔案) |
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ō),是為了兼容><之類(lèi)的運(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)算符。
到此,關(guān)于“如何理解linux shell邏輯運(yùn)算符、邏輯表達(dá)式”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)?lái)更多實(shí)用的文章!