1.數(shù)組
① 變量:存儲單個(gè)元素的內(nèi)存空間
② 數(shù)組:存儲多個(gè)元素的連續(xù)的內(nèi)存空間蒜魄,相當(dāng)于多個(gè)變量的集合
③ 數(shù)組名和索引
索引:編號從0開始扫俺,屬于數(shù)值索引
注意:索引可支持使用自定義的格式汗菜,而不僅是數(shù)值格式,即為關(guān)聯(lián)索引虎囚,bash4.0版本之后開始支持bash的數(shù)組支持稀疏格式(索引不連續(xù))
2.聲明數(shù)組:
declare -a ARRAY_NAME
declare -A ARRAY_NAME: 關(guān)聯(lián)數(shù)組
注意:兩者不可相互轉(zhuǎn)換
3.數(shù)組元素的賦值
(1) 一次只賦值一個(gè)元素
ARRAY_NAME[INDEX]=VALUE
(2) 一次賦值全部元素
ARRAY_NAME=("VAL1" "VAL2" "VAL3" ...)
(3) 只賦值特定元素
ARRAY_NAME=([0]="VAL1" [3]="VAL2" ...)
(4) 交互式數(shù)組值對賦值
read -a ARRAY
(5)顯示所有數(shù)組:declare -a
4.引用數(shù)組
① 引用數(shù)組元素:
${ARRAY_NAME[INDEX]}
注意:省略[INDEX]表示引用下標(biāo)為0的元素
② 引用數(shù)組所有元素:
${ARRAY_NAME[*]}
${ARRAY_NAME[@]}
③數(shù)組的長度(數(shù)組中元素的個(gè)數(shù)):
${#ARRAY_NAME[*]}
${#ARRAY_NAME[@]}
④ 刪除數(shù)組中的某元素:導(dǎo)致稀疏格式
unset ARRAY[INDEX]
⑤ 刪除整個(gè)數(shù)組:
unset ARRAY
5.數(shù)組數(shù)據(jù)處理
(1) 引用數(shù)組中的元素:
數(shù)組切片:${ARRAY[@]:offset:number}
offset: 要跳過的元素個(gè)數(shù)
number: 要取出的元素個(gè)數(shù)
取偏移量之后的所有元素
${ARRAY[@]:offset}
(2) 向數(shù)組中追加元素:
ARRAY[${#ARRAY[*]}]=value
(3) 關(guān)聯(lián)數(shù)組:
declare -A ARRAY_NAME
ARRAY_NAME=([idx_name1]='val1' [idx_name2]='val2‘...)
注意:關(guān)聯(lián)數(shù)組必須先聲明再調(diào)用
eg:
(1)生成10個(gè)隨機(jī)數(shù)保存于數(shù)組中横缔,并找出其最大值和最小值
#!/bin/bash
declare -a rand
declare -i max=0
declare –i min=32767
for i in {0..9}; do
rand[$i]=$RANDOM
echo ${rand[$i]}
[ ${rand[$i]} -gt $max ] && max=${rand[$i]}
[ ${rand[$i]} -lt $min ] && min=${rand[$i]}
done
echo "Max: $max Min:$min"
(2)編寫腳本,定義一個(gè)數(shù)組己肮,數(shù)組中的元素是/var/log目錄下所有以
.log結(jié)尾的文件士袄;統(tǒng)計(jì)出其下標(biāo)為偶數(shù)的文件中的行數(shù)之和
#!/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