[ root@hadoop /]# echo $(( a+=1 ))9[ root@hadoop /]# echo $(( 3>2 ))1[ root@hadoop /]# echo $(( 3>8 ))0[ root@hadoop /]# echo $(( 100*(100+1)/2 ))5050
eg:[ root@hadoop /]# i=2[ root@hadoop /]# let i=i+8[ root@hadoop /]# echo $i10
用法一:[root@hadoop /]# expr 1+91+9 (注意计算的时候要有 空格 )[ root@hadoop /]# expr 1 + 23[ root@hadoop /]# expr 3 - 12[ root@hadoop /]# expr 3 /* 2expr: 语法错误 (要加/给*转译)[ root@hadoop /]# expr 3 \* 26[ root@hadoop /]# expr 7 / 51
用法二:[root@hadoop /]# expr $[2+3]5[root@hadoop /]# expr $[3/2]1[root@hadoop /]# expr $[2%3]2[root@hadoop /]# expr $[2*3]6
用法三:判断字符串的长度[ root@hadoop workspace]# echo $(expr length "123456")6eg:输入一个参数,判断是否是整数#Author:gaoq#Date:2015-06-02#Email: 1473418313@qq.comwhile truedoread -p "请输入:" aexpr $a + 0 >/dev/null 2>&1[ $? -eq 0 ] &&echo int||echo charsdone
1表示系统标准输出, 系统默认值是1, > /dev/null等同于1 > /dev/null
对于 >dev/null 2>&1
1>/dev/null :首先表示标准输出重定向到空设备文件,也就是不输出任何信息到终端,说白了就是不显示任何信息
2>&1 : 标准错误输出重定向 到 标准输出,因为之前标准输出已经重定向到了空设备文件,所以标准错误输出也重定向到空设备文件
comand > file 2>file 与 comand >file 2>&1
command > file 2>file 的意思是将命令所产生的标准输出信息,和错误的输出信息送到file 中.command > file 2>file 这样的写法,stdout和stderr都直接送到file中, file会被打开两次,这样stdout和stderr会互相覆盖,这样写相当使用了FD1和FD2两个同时去抢占file 的管道
而command >file 2>&1 这条命令就将stdout直接送向file, stderr 继承了FD1管道后,再被送往file,此时,file 只被打开了一次,也只使用了一个管道FD1,它包括了stdout和stderr的内容
从IO效率上,前一条命令的效率要比后面一条的命令效率要低,所以在编写shell脚本的时 候,较多的时候我们会command > file 2>&1 这样的写法
Linux Shell 环境中支持输入输出重定向,用符号<和>来表示。0、1和2分别表示标准输入、标准输出和标准错误信息输出,可以用来指定需要重定向的标准输 入或输出,比如 2>a.txt 表示将错误信息输出到文件a.txt中。
同时,还可以在这三个标准输入输出之间实现重定向,比如将 错误信息重定向到标准输出,可以用 2>&1来实现。
Linux下还有一个特殊的文件/dev/null,它就像一个无底 洞,所有重定向到它的信息都会消失得无影无踪。这一点非常有用,当我们不需要回显程序的所有信息时,就可以将输出重定向到/dev/null。
如 果想要正常输出和错误信息都不显示,则要把标准输出和标准错误都重定向到/dev/null, 例如:
# ls 1>/dev/null 2>/dev/null
还有一种做法是将错误重定向到标准输出,然后再重定向到 /dev/null,例如:
# ls >/dev/null 2>&1
注意:此处的顺序不能更改,否则 达不到想要的效果,此时先将标准输出重定向到 /dev/null,然后将标准错误重定向到标准输出,由于标准输出已经重定向到了/dev/null,因此标准错误也会重定向到/dev/null,于 是一切静悄悄:-)
四:dc用法(支持小数处理,支持进制转换)
eg:
[ root@hadoop workspace]# echo 1+3|bc4[ root@hadoop workspace]# echo 5.23/3.13|bc1[ root@hadoop workspace]# echo " scale=2;5.23 "|bc5.23 (注释: scale=2;保留两位小数 )[ root@hadoop workspace]# echo " scale=2;5.23/3.13 "|bc1.67[ root@hadoop workspace]# echo " obase=2;8 "|bc1000 (注释: obase=2;转换为二进制 )
[ root@hadoop workspace]# typeset -i a=1 b=2[ root@hadoop workspace]# a=a+b --------效率高[ root@hadoop workspace]# echo $a3
[ root@hadoop workspace]# typeset -i a=1 b=2[ root@hadoop workspace]# a=a+b[ root@hadoop workspace]# echo $a3[root@hadoop workspace]# echo $[3+2]5[root@hadoop workspace]# echo $[a+b]5