Linux Bash Shell学习(十六):数组
数组元素可以是string或者数字,同变量一样。数组的index从0开始 计算,最大可以为599147937791。基本上可以认为没有限制。
定义方式
可以直接进行赋值
name[2]=two
name[0]=zero
name[1]=one
与上面方式一样,这里我们没有按顺序进行赋值。name=([2]=alice [0]=hatter [1]=duchess) 。如果我们按顺序进行赋值,可以不需要说明index,name=(a b c) 。如果我们其中有一个不依次赋值,可以指明,如name=(a [3]=b c) ,b赋值给index=3的元素,c按顺序赋值给下一个,即index=4。
如果我们定义一个空的数组,可以使用declare –a name 来声明。变量用${array [i ]} ,如果没有指明index,则返回第0个元素。
重置和取消
我们使用组合方式定义,即array=(…)的方式时,如果前面已经定义了数组,将重置整个数组。
如果我们要取消某个元素,可以使用unset array [i] ,如果我们要出现整个数组,可以使用unset array ,或者unset array [@] 和unset array [*] 。
@,*和#
和位置参数一样,也可以使用@和*,使用*的时候,间隔为IFS。在上面的例子中echo ${name[@]}为zero one two。这可以用for的循环中:
for entry in "${name[@]}"; do
echo --$entry--
done
如果index不存在,没有赋值,返回null,在${array[@]}中,不包含这些元素,只有有效值。例如:
table=([1]=one [3]=three)
#${array [@]}获取所有元素内容信息
echo ${table[@]}
#${!array [@]}获取所有元素序号信息
echo ${!table[@]}
for entry in ${table[@]}; do
echo ==$entry==
done
运行结果如下:
one three
1 3
==one==
==three==
如果需要每个元素都显现,可以使用for((i=0;i<=3;i++)) 的方式。
#是长度的操作,${#array [i ]} 将返回第i元素的字符串的长度。而${#array [@]} 则返回有效元素的格式,例如上面的例子中${#table[@]}为2。
例子一 :利用/etc/passwd,通过用户ID获取用户名:
for entry in $(cut -f 1,3 -d: /etc/passwd); do
#${entry#*:}是前面的用户 ID,${entry%:*}是后面的用户名
echo "set array[${entry#*:}]=${entry%:*}"
array[${entry#*:}]=${entry%:*}
done
echo "User ID $1 is ${array[$1]}."
echo "There are currently ${#array[@]} user accounts on the system."
例子二 :冒泡算法
#设置数组values
values=(39 5 36 12 9 3 2 30 4 18 22 1 28 25)
#获取values的个数
numvalues=${#values[@]}#显示当前数组的值,用于跟踪
function showvalues
{
for (( k=0; k < numvalues; k++)); do
echo -ne "${values[$k]} "
done
echo
}#冒泡算法 :将被排序的记录数组R[1..n]垂直排列,每个记录R看作是重量 为R.key的气泡。根据轻气泡不能在重气泡之下的原则,从下往上扫描数组R:凡扫描到违反本原则的轻气泡,就使其向上"飘浮"。如此反复进行,直到最后 任何两个气泡都是轻者在上,重者在下为止。
function bubble
{
for (( i=0; i < numvalues; i++));do
ischanged=false
for((j=numvalues-1; j> i; j--));do
# 如果轻的在下交换之,每次i的循环,都可以见最轻的放置在最上,并调整其他的位置,使之更为有序
if [ ${values[j]} -lt ${values[j-1]} ];then
temp=${values[j]}
values[j]=${values[j-1]}
values[j-1]=$temp
ischanged=true
fi
done
showvalues
#如果已经不需要调整,即有序,就跳出循环。
if [ ischanged = "false" ] ;then
break;
fi
done
}