這篇文章主要介紹“如何理解linux shell邏輯運(yùn)算符、邏輯表達(dá)式”,在日常操作中,相信很多人在如何理解linux shell邏輯運(yùn)算符、邏輯表達(dá)式問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”如何理解linux shell邏輯運(yùn)算符、邏輯表達(dá)式”的疑惑有所幫助!接下來,請跟著小編一起來學(xué)習(xí)吧!

一、邏輯運(yùn)算符
| 邏輯卷標(biāo) | 表示意思 |
| 1. | 關(guān)于檔案與目錄的偵測邏輯卷標(biāo)! |
| -f | 常用!偵測『檔案』是否存在 eg: if [ -f filename ] |
| -d | 常用!偵測『目錄』是否存在 |
| -b | 偵測是否為一個(gè)『 block 檔案』 |
| -c | 偵測是否為一個(gè)『 character 檔案』 |
| -S | 偵測是否為一個(gè)『 socket 標(biāo)簽檔案』 |
| -L | 偵測是否為一個(gè)『 symbolic link 的檔案』 |
| -e | 偵測『某個(gè)東西』是否存在! |
| 2. | 關(guān)于程序的邏輯卷標(biāo)! |
| -G | 偵測是否由 GID 所執(zhí)行的程序所擁有 |
| -O | 偵測是否由 UID 所執(zhí)行的程序所擁有 |
| -p | 偵測是否為程序間傳送信息的 name pipe 或是 FIFO (老實(shí)說,這個(gè)不太懂!) |
| 3. | 關(guān)于檔案的屬性偵測! |
| -r | 偵測是否為可讀的屬性 |
| -w | 偵測是否為可以寫入的屬性 |
| -x | 偵測是否為可執(zhí)行的屬性 |
| -s | 偵測是否為『非空白檔案』 |
| -u | 偵測是否具有『 SUID 』的屬性 |
| -g | 偵測是否具有『 SGID 』的屬性 |
| -k | 偵測是否具有『 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)算符號 | 代表意義 |
| = | 等于 應(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ò)充。能夠支持<,>符號運(yùn)算不需要轉(zhuǎn)義符,它還是以字符串比較大小。里面支持邏輯運(yùn)算符:|| &&
三、性能比較
bash的條件表達(dá)式中有三個(gè)幾乎等效的符號和命令: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
不考慮對低版本bash和對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)知識,請繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!
文章名稱:如何理解linuxshell邏輯運(yùn)算符、邏輯表達(dá)式-創(chuàng)新互聯(lián)
標(biāo)題路徑:http://chinadenli.net/article2/cddpic.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站內(nèi)鏈、搜索引擎優(yōu)化、建站公司、外貿(mào)建站、Google、用戶體驗(yàn)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容