一、case–esac
case … esac 与其他语言中的 switch … case 语句类似,是一种多分枝选择结构。
case 语句匹配一个值或一个模式,如果匹配成功,执行相匹配的命令。case语句格式如下
prepare_step(){
echo “ddddd”
1case“
1” in
“0”)
setp_name=pythonStyle
;;
“1”)
setp_name=compi
;;
“2”)
setp_name=unittest
;;
“3”)
setp_name=find
;;
esac
}
二、shift
右移
isStepNeeded(){
para1=”
1”shiftecho
para1
para2=”
@”echo“jjjjjjjjjj”echo“
para2" | grep -w "$para1” >/dev/null
echo “dddddddd”
}
eg:
测试 shift 命令(x_shift.sh)
until [ # -eq 0 ]
do
echo “第一个参数为:1 参数个数为: #”
shift
done
执行以上程序x_shift.sh:./x_shift.sh 1 2 3 4
结果显示如下:
第一个参数为: 1 参数个数为: 4
第一个参数为: 2 参数个数为: 3
第一个参数为: 3 参数个数为: 2
第一个参数为: 4 参数个数为: 1
三、grep
-v 显示不包含匹配文本的所有行
echo “
para2"|grep−w"
para1” >/dev/null
——>/dev/null —送到无底洞。。。
在Linux/Unix中,一般在屏幕上面看到的信息是从stdout (standard output) 或者 stderr (standard error output) 来的。许多人会问,output 就是 output,送到屏幕上不就得了,为什麼还要分成stdout 和 stderr 呢?那是因为通常在 server 的工作环境下,几乎所有的程序都是 run 在 background 的,所以呢,为了方便 debug,一般在设计程序时,就把 stdout 送到/存到一个档案,把错误的信息 stderr 存到不同的档案。
哪些是正常的output呢,例如程序开始运行的时间,现在正在上线人数等等。
哪些是错误的output呢,例如无法找到使用者想要去的URL,或者信用卡认证失败等等。
有了上面这些认知后,回头来讲什麼是 > /dev/null
这是把 stdout 送到 /dev/null 里面
那什麼是 /dev/null 呢,/dev/null 是 Unix/Linux 里的【无底洞】
任何的 output 送去了【无底洞】就再也没了。相信我,真的没了!
那麼有人问,在什麼情况下要把 output 送去这无底洞呢?
这里没有标准答案,
不过一般呢,要是你不想看到 output 或者output 太多太大了,有可能把硬碟给挤爆了的时候,程序的设计就会考虑把 output 送到 /dev/null 了。