zoukankan      html  css  js  c++  java
  • Shell 之数组 [转]

    本文也即《Learning the bash Shell》3rd Edition的第六章Command-Line Options and Typed varilables之读书笔记之三,但我们将不限于此。数组元素可以是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
    }

  • 相关阅读:
    HP Nonstop SQLMX (SPJ) Stored Procedure in Javas Getting Started
    Term of Wall Street
    iOS自带地图纠偏问题
    Android 界面排版的5种方式
    Android底部导航栏
    Android中Intent传值与Bundle传值的区别详解
    Android开发EditText属性
    从点击一个链接到浏览器显示页面,这个过程中发生了什么?
    HTML的常用标签属性及使用时需注意的一些细节
    写一个简单的脚本,并在脚本生成的的文件中添加内容
  • 原文地址:https://www.cnblogs.com/jackluo/p/3429978.html
Copyright © 2011-2022 走看看