Linux Bash Shell学习(十六):数组

By admin  2011年02月02日 Linux 关注度 27,820 添加评论

数组元素可以是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
}

发表评论