q1.数组

  我们知道,变量就是内存里的存储空间,每个变量只可以存储一个数据,进行一次性的赋值操作,那么遇到一些需要连续存储并读取的任务时,如果还是依靠变量进行多次存储,既不会保证内存空间的连续性,也大大降低了CPU的效率,这时就需要数组这一类型的变量出马了!

数组变量:

 数组简单来说就是存放一个或多个元素的连续的内存空间,相当于多个变量的集合;

数组的索引有以下方式:

   1.数字索引。称为索引数组 Index ARRAY;

     0,1,2,3....

   2.名称(字符串): 称为关联数组 Related ARRAY;

     bash4.0以上的版本才支持

数组分为两种:稠密数组和稀疏数组

  稠密数组:索引编号必须连续,类似于连续函数依次排序,没有断点;

  稀疏数组:索引编号可以不连续,bash数组就属于稀疏数组;

声明数组的方法:

  1.之前说到的declare命令,可以声明变量。

    -i NAME 声明整型变量

    -x NAME 声明环境变量

   同样,用它也可以声明数组变量

    -a:声明索引数组(if supported)

    -A:声明关联数组(if supported)

  2.直接声明数组

   直接为数组赋值:

    ARRAY_NAME=("value1" "value2" ...)  稠密数组

    ARRAY_NAME=([0]="value1" [5]="value2" ...)  稀疏数组

  3.定义数组的元素而创建数组

    ARRAY_NAME[0]=value1

    ARRAY_NAME[1]=value2

    ...

以下介绍对数组的操作:

1.引用数组的元素:

   引用数组元素的方式:${ARRAY_NAME[INDEX]}

     注意:如果不给出索引编号index,则表示引用数组的第一个元素

   引用整个数组所有元素:${ARRAY_NAME[*/@]}

   引用数组的索引:${!ARRAY_NAME[*/@]}

2.查看数组的长度:数组中有效元素的个数:

    ${#ARRAY_NAME[*/@]}

3.数组切片:

  ${ARRAY_NAME:offset}显示包括offset数字所表示的索引位置及以后的所有元素

4.追加元素:

  1).稠密数组:

   ARRAY_NAME[${#ARRAY_NAME[*]}]=valuex

  2).稀疏数组

   ARRAY_NAME[INDEX]=valuex  这里的index必须为未被使用的数组元素索引编号;

5.撤销数组

  unset ARRAY_NAME

6.删除数组的元素

  unset ARRAY_NAME[INDEX]

关于数组简单的记到这里,数组方便我们对大量数据的存储,读取等操作,用处是大大的