数组ARRAY

  数组ARRAY是一种特殊的数据结构,可以在此数据结构上设计算法,实现一些复杂的应用实现。

一、数组介绍

1、定义

数组是存储多个类似元素的连续的内存空间,和变量相比,变量是存储单个元素的内存空间。

2、申明

declare -a ARRAY_NAME
declare -A ARRAY_NAME:关联数组,如ARRAY_NAME=([index_name]='val1' [index_name2]='val2' ......)

注意:两者不可相互转换;关联数组必须先声明再调用

3、数组名和索引

索引:编号从0开始,属于数值索引(注意:索引可支持使用自定义的格式,而不仅是数值格式,即为关联索引,bash4.0版本之后开始支持)

4、数组元素的赋值

(1) 一次只赋值一个元素:

ARRAY_NAME[INDEX]=VALUE

weekdays[0]="Sunday"

weekdays[4]="Thursday"

(2) 一次赋值全部元素:

ARRAY_NAME=("VAL1" "VAL2" "VAL3" ......)

(3) 只赋值特定元素:

ARRAY_NAME=([0]="VAL1" [3]="VAL2" ...)

(4)交互式数组值对赋值

read -a ARRAY

显示所有数组:declare -a

5、引用数组

(1)引用数组元素:

${ARRAY_NAME[INDEX]}
注意:省略[INDEX]表示引用下标为0的元素

(2)引用数组所有元素:

${ARRAY_NAME[*]}
${ARRAY_NAME[@]}

(3)数组的长度(数组中元素的个数):

${#ARRAY_NAME[*]}
${#ARRAY_NAME[@]}

(4)删除数组中的某元素:导致稀疏格式

unset ARRAY[INDEX]

注:稀疏格式是指数组的下标不连接

(5)删除整个数组:

unset ARRAY

(6)数组切片

${ARRAY[@]:offset:number} 
offset: 要跳过的元素个数
number:要取出的元素个数

${ARRAY[@]:offset}:取偏移量之后的所有元素

(7)向数组中追加元素

ARRAY[${#ARRAY[*]}]=value (利用到了数组的下标是从0开始计数,而数组的长度是从1开始计数,所以数组长度一定是新追加元素的下标)

 

二、数组在shell脚本中的应用

实验一:生成10个随机数,并找出其最大值

declare -a rand
declare -i max=0

for i in {0..9}; do
rand[$i]=$RANDOM
echo "${rand[$i]}"
[ ${rand[$i]} -gt $max ] && max=${rand[$i]}
done
echo "Max: $max"

实验二:生成10个随机数保存于数组中,并找出其最大值和最小值

#!/bin/bash
declare -i min max
declare -a nums
for ((i=0;i<10;i++));do
nums[$i]=$RANDOM
[ $i -eq 0 ] && min=${nums[$i]} && max=${nums[$i]}&& continue
[ ${nums[$i]} -gt $max ] && max=${nums[$i]}
[ ${nums[$i]} -lt $min ] && min=${nums[$i]}
done
echo “All numbers are ${nums[*]}”
echo Max is $max
echo Min is $min

实验三:编写脚本,定义一个数组,数组中的元素是/var/log目录下所有以.log结尾的文件;统计出其下标为偶数的文件中的行数之和

#!/bin/bash
#
declare -a files
files=(/var/log/*.log)
declare -i lines=0
for i in $(seq 0 $[${#files[*]}-1]); do
if [ $[$i%2] -eq 0 ];then
let lines+=$(wc -l ${files[$i]} | cut -d' ' -f1)
fi
done
echo "Lines: $lines."

三、数组在awk中的应用

在awk中,关联数组的用法最为常见。

1、定义

关联数组:array[index-expression]
index-expression:
(1) 可使用任意字符串,字符串要使用双引号
(2) 如果某数组元素事先不存在,在引用时,awk会自动创建此元素,并将其值初始化为"空串"

若要判断数组中是否存在某元素,要使用"index in array"格式进行
若要遍历数组中的每一个元素,要使用for循环:
for(var in array)(for-body) 注意:var会遍历array的每个索引

2、实验

awk 'BEGIN{weekdays["mon"]="Mon";weekdays["tue"]="Tues";print weekdays["mon"]}'
awk 'BEGIN{weekdays["mon"]="Mon";weekdays["tue"]="Tues";for (i in weekdays)print weekdays[i]}'

netstat -tan | awk '/^tcp\>/{state[$NF]++}END{for(i in state) print i,state[i]}'
awk '{IP[$1]++}END{for(i in IP)print i,IP[i]}' access_log
练习:统计/etc/fstab文件系统类型出现的次数
awk '/^UUID\>/{FILESYS[$3]++}END{for(i in FILESYS)print i,FILESYS[i]}' /etc/fstab
练习:统计/etc/fstab文件中每个单词出现的次数
awk '{for(i=1;i<=NF;i++){count[$i]++}}END{for(i in count)print i,count[i]}' /boot/grub2/grub.cfg

猜你喜欢

转载自www.cnblogs.com/liangjindong/p/9072223.html