使用expr进行计算的时候,变量必须是整数,不能是字符串,也不能含小数,否则会出错(命令的退出状态为非0):
$ i=hello
$ expr $i + 58
expr: non-integer argument
$ echo $?
2
利用命令expr的这一特点,可以判断某个变量是不是整数。让其参与整数运算,比如,与1相加,如果expr命令的退出状态是0(成功),表明该变量是整数,否则不是整数。见下列:
$ k=5
$ expr 1 + $k >/dev/null 2>&1# 这里只关心命令的退出状态,不关心值是多少,
# 所以将标准输出与标准错误都重定向到"黑洞"
$ echo $?
0 # 退出状态为0,说明k是整数
$ m=5.8
$ expr 1 + $m >/dev/null 2>&1
$ echo $?
2 # 退出状态非0,说明m不是整数
acsii表里面,字母有对应的编码范围,数字也有对应的编码范围,把char型变量可以用acsii码表示,通过acsii码可以实现字符检测。这个似乎和linux没有必然联系,属于编程基础。学任何一门语言,任何一个系统平台都要知道这个算法。
shell字符串比较、判断是否为数字
二元比较 *** 作符,比较变量或者比较数字。注意数字与字符串的区别。
整数比较
-eq 等于,如:if [ "$a" -eq "$b" ]
-ne 不等于,如:if [ "$a" -ne "$b" ]
-gt 大于,如:if [ "$a" -gt "$b" ]
-ge 大于等于,如:if [ "$a" -ge "$b" ]
-lt 小于,如:if [ "$a" -lt "$b" ]
-le 小于等于,如:if [ "$a" -le "$b" ]
<小于(需要双括号),如:(("$a" <"$b"))
<= 小于等于(需要双括号),如:(("$a" <= "$b"))
>大于(需要双括号),如:(("$a" >"$b"))
>= 大于等于(需要双括号),如:(("$a" >= "$b"))
字符串比较
= 等于,如:if [ "$a" = "$b" ]
== 等于,如:if [ "$a" == "$b" ],与=等价
注意:==的功能在[[]]和[]中的行为是不同的,如下:
1 [[ $a == z* ]] # 如果$a以"z"开头(模式匹配)那么将为true
2 [[ $a == "z*" ]] # 如果$a等于z*(字符匹配),那么结果为true
3
4 [ $a == z* ] # File globbing 和word splitting将会发生
5 [ "$a" == "z*" ] # 如果$a等于z*(字符匹配),那么结果为true
一点解释,关于File globbing是一种关于文件的速记法,比如"*.c"就是,再如~也是.
但是file globbing并不是严格的正则表达式,虽然绝大多数情况下结构比较像.
!= 不等于,如:if [ "$a" != "$b" ]
这个 *** 作符将在[[]]结构中使用模式匹配.
<小于,在ASCII字母顺序下.如:
if [[ "$a" <"$b" ]]
if [ "$a" \<"$b" ]
注意:在[]结构中"<"需要被转义.
>大于,在ASCII字母顺序下.如:
if [[ "$a" >"$b" ]]
if [ "$a" \>"$b" ]
注意:在[]结构中">"需要被转义.
具体参考Example 26-11来查看这个 *** 作符应用的例子.
-z 字符串为"null".就是长度为0.
-n 字符串不为"null"
链接:https://www.jianshu.com/p/6322715ad196
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)