先看脚本示例:test-arr.sh
#!/usr/bin/env bash
set -e
NUM=0
RELPLICAS=5
for i in {1,2,3,4,5};do
REPLICAS_COUNT[${NUM}]="${RELPLICAS}"
((NUM++))
((RELPLICAS++))
echo ${REPLICAS_COUNT[*]}
done
然后sh -x test-arr.sh 调试看执行过程。
[root@tylw shell]# sh -x test-arr.sh
+ set -e
+ NUM=0
+ RELPLICAS=5
+ for i in '{1,2,3,4,5}'
+ REPLICAS_COUNT[${NUM}]=5
+ (( NUM++ ))
可以看到执行到 (( NUM++ )) 时退出了,当时觉得很奇怪,因为以前这样写过没问题,回想了一下差别,也测试了其他环境,得出结论是在 set -e (set -o errexit)这里出了,这句含义是遇到错误就停止不再继续后面的语句,测试注释的这句,脚本就能跑成功。
后面查询资料得知 ((NUM++)) 这样运算是整数运算,初始值不能为0,于是把修改NUM=1,开启 set -e ,这次就没问题了。
看演示:
#!/usr/bin/env bash
set -e
NUM=1
RELPLICAS=5
for i in {1,2,3,4,5};do
REPLICAS_COUNT[${NUM}]="${RELPLICAS}"
((NUM++))
((RELPLICAS++))
echo ${REPLICAS_COUNT[*]}
done
再次sh -x test-arr.sh ,执行过程如下
sh -x test-arr.sh
+ set -e
+ NUM=1
+ RELPLICAS=5
+ for i in '{1,2,3,4,5}'
+ REPLICAS_COUNT[${NUM}]=5
+ (( NUM++ ))
+ (( RELPLICAS++ ))
+ echo 5
5
+ for i in '{1,2,3,4,5}'
+ REPLICAS_COUNT[${NUM}]=6
+ (( NUM++ ))
+ (( RELPLICAS++ ))
+ echo 5 6
5 6
+ for i in '{1,2,3,4,5}'
+ REPLICAS_COUNT[${NUM}]=7
+ (( NUM++ ))
+ (( RELPLICAS++ ))
+ echo 5 6 7
5 6 7
+ for i in '{1,2,3,4,5}'
+ REPLICAS_COUNT[${NUM}]=8
+ (( NUM++ ))
+ (( RELPLICAS++ ))
+ echo 5 6 7 8
5 6 7 8
+ for i in '{1,2,3,4,5}'
+ REPLICAS_COUNT[${NUM}]=9
+ (( NUM++ ))
+ (( RELPLICAS++ ))
+ echo 5 6 7 8 9
5 6 7 8 9
最后总结,在用set -e 写调试脚本的时候,如果有自增运算,记得关闭或者初始值大于等于1,另外,数组中的下标起始值是位是0,本例中的数组原始设计是从0位开始统计,由于自增运算的机制,调试的时候NUM=1,这种情况下数组的第一个下标位是缺失的,引用的时候要注意下标位!