下面給大家介紹的關于shell的基本計算、邏輯運算、位運算相關的解析,你可能還不知道,下面我門一起來看看,希望對需要的朋友有所幫助! 以下面的格式提供運算表達式:$(( expression )) $ echo $((5*(3+3))) 30 $ result = $(($myvar-10)) shell提供方便的數之間的進制轉換: $ echo $((013))#八進制 $ echo $((0xA4))#十六進制 還可以使用以下格式指定 2 到 64 之間的任意進制: $((BASE#NUMBER)) echo $((8#377)) echo $((16#D8)) 在 Shell 中進行進制轉換的另一個訣竅是使用 bc, 它是一種任意精度運算語言,大多數 UNIX 安裝程序都提供。因為它允許您指定輸出進制,所以當您需要以十進制以外的進制輸出時,這是一種很好的技術。 bc 的特殊變量 ibase 和 obase 分別包含用于輸入和輸出的進制的值。缺省情況下,都被設置為 10。要執行進制轉換,需要改變其中的一個或兩個值,然后提供一個數字。 $ echo 'obase=16; 47' | bc 2F $ echo 'obase=10; ibase=16; A03' | bc 2563 了解了這些基本特性,下邊再看看邏輯運算符和邏輯表達式,基本的 + – * / % 不再贅述。 一、邏輯運算符
二、邏輯表達式 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 注意:所有字符 與邏輯運算符直接用“空格”分開,不能連到一起。 精簡表達式 [] 表達式 [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 `]‘ 注意:在[] 表達式中,常見的>,<需要加轉義字符,表示字符串大小比較,以acill碼 位置作為比較。 不直接支持<>運算符,還有邏輯運算符|| && 它需要用-a[and] –o[or]表示 [[]] 表達式 [root@localhost ~]# [ 1 -eq 1 ] && echo ‘ok' ok[root@localhost ~]$ [[ 2 < 3 ]] && echo ‘ok' ok [root@localhost ~]$ [[ 2 < 3 && 4 > 5 ]] && echo ‘ok' ok 注意:[[]] 運算符只是[]運算符的擴充。能夠支持<,>符號運算不需要轉義符,它還是以字符串比較大小。里面支持邏輯運算符:|| && 三、性能比較 bash的條件表達式中有三個幾乎等效的符號和命令:test,[]和[[]]。通常,大家習慣用if [];then這樣的形式。而[[]]的出現,根據ABS所說,是為了兼容><之類的運算符。以下是比較它們性能,發現[[]]是最快的。 $ 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的兼容的情況下,用[[]]是兼容性強,而且性能比較快,在做條件運算時候,可以使用該運算符。 四、按位操作運算符
注: 對于按位非,若求“~a”則結果為-(a+1)舉一個詳細例子:求“~8”分析由于計算機通常 用補碼進行符號運算,[[x]補]補=[x]所以 則8的二進制為00001000 求非為11110111 求反碼為1001000求補碼為1001001所以最后的結果為1001001,~8 即為-9。 以上關于shell的基本計算、邏輯運算、位運算相關的解析就是小編為大家收集整理的全部內容了,希望對大家有所幫助。如果您喜歡這篇文章,可以收藏或分享給您的小伙伴們吧!歡迎持續關注我們的后續更新。 |
免責聲明:本站部分文章和圖片均來自用戶投稿和網絡收集,旨在傳播知識,文章和圖片版權歸原作者及原出處所有,僅供學習與參考,請勿用于商業用途,如果損害了您的權利,請聯系我們及時修正或刪除。謝謝!
始終以前瞻性的眼光聚焦站長、創業、互聯網等領域,為您提供最新最全的互聯網資訊,幫助站長轉型升級,為互聯網創業者提供更加優質的創業信息和品牌營銷服務,與站長一起進步!讓互聯網創業者不再孤獨!
掃一掃,關注站長網微信