Linux之数组

 

Linux之数组

 

 

数组介绍
数组:存储多个元素的连续的内存空间,相当于多个变量的集合。

变量:存储单个元素的内存空间数组名和索引
索引:编号从0开始,属于数值索引
注意:索引可支持使用自定义的格式,而不仅是数值格式,即为关联索引,bash4.0版本之后开始支持。
bash的数组支持稀疏格式(索引不连续)
声明数组:
declare -a ARRAY_NAME
declare -A ARRAY_NAME: 关联数组

 

数组赋值
数组元素的赋值:
(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

 

引用数组
引用数组元素:${ARRAY_NAME[INDEX]}
注意:省略[INDEX]表示引用下标为0的元素
数组的长度(数组中元素的个数):
${#ARRAY_NAME[*]}
${#ARRAY_NAME[@]}
示例:生成10个随机数保存于数组中,并找出其最大值和最小值
#!/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"

 

示例
编写脚本,定义一个数组,数组中的元素是/var/log目录下所有以.log结尾的文件;要统计其下标为偶数的文件中的行数之和
#!/bin/bash
#
declare -a files
files=(/var/log/*.log)
declare -ilines=0
for iin $(seq0 $[${#files[*]}-1]); do
if [ $[$i%2] -eq0 ];then
let lines+=$(wc-l ${files[$i]} | cut -d' ' -f1)
fi
done
echo "Lines: $lines."

 

数组数据处理
引用数组中的元素:
所有元素:${ARRAY[@]}, ${ARRAY[*]}
数组切片:${ARRAY[@]:offset:number}
offset: 要跳过的元素个数
number: 要取出的元素个数
取偏移量之后的所有元素${ARRAY[@]:offset}
向数组中追加元素:
ARRAY[${#ARRAY[*]}]
删除数组中的某元素:导致稀疏格式
unset ARRAY[INDEX]
关联数组:
declare -A ARRAY_NAME 注意:必须先声明,再调用
ARRAY_NAME=([idx_name1]='val1' [idx_name2]='val2‘…)

 

 

 

 

 

练习和作业

 

 

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

 

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

 

===================================================

 

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

 

 

1、生成10个随机数,采用冒泡算法进行升序或降序排序

 

#!/bin/sh
echo "please input a number list:"
read -a arr

 

for (( i=0 ; i<${#arr[@]} ; i++ ))
do
  for (( j=${#arr[@]}- 1 ; j>i ; j– ))
  do
    #echo $j
    if  [[ ${arr[j]} -lt ${arr[j-1]} ]]
    then
       t=${arr[j]}
       arr[j]=${arr[j-1]}
       arr[j-1]=$t
    fi
  done
done
echo "after ascending sorting:"
echo ${arr[@]}

 

for (( i=0 ; i<${#arr[@]} ; i++ ))
do
  for (( j=${#arr[@]}- 1 ; j>i ; j– ))
  do
    #echo $j
    if  [[ ${arr[j]} -gt ${arr[j-1]} ]]
    then
       t=${arr[j]}
       arr[j]=${arr[j-1]}
       arr[j-1]=$t
    fi
  done
done
echo "after descending sorting:"
echo ${arr[@]}

 

 

1、让用户(管理员或所有用户)的PATH环境变量的值多出一个路径,例如多如/usr/local/apache2/bin

 

cd /etc/profile.d/
vim apache2.sh
PATH=$PATH:/usr/local/apache2/bin

 

 

2、用户wang登录时自动启用别名rm=‘rm –i’

 

vim .bashrc
alias rm=rm -i

 

 

3、用户登录时,显示红色字体的警示提醒信息“hi,dangerous!”

 

cd /etc/profile.d/
vim login.sh
echo -e "\033[31mdangerous\033[0m"

 

 

 

 

 

 

 

原创文章,作者:dengjian,如若转载,请注明出处:http://www.178linux.com/39929

(1)
dengjiandengjian
上一篇 2016-08-25 10:09
下一篇 2016-08-25 10:09

相关推荐

  • http协议基础(一)

    web服务:      Apache      Nginx      LVS      http协议 网站运维:      web站点      游戏网站web服务 高性能,高可用…

    Linux干货 2017-04-18
  • 根据作业浅析正则表达式

        什么是正则?正则就是,那种体现出某种规律的不变性或者对称性的物理量或关系。     正则表达式(Regular Expression):由一类特殊字符及文本字符所编写的模式,其中有些字符(元字符)不表示字符字面意义,而表示控制或通配的功能(linux中,可以使用:man …

    Linux干货 2017-07-30
  • 网络21期第十周博客作业

    网络21期第十周博客作业 1、请详细描述CentOS系统的启动流程(详细到每个过程系统做了哪些事情) Centos6启动流程:       POST加电自检 —> BOOT Sequence —> 加载内核启动系统  &…

    Linux干货 2016-09-15
  • LVS的简介和配置

    lvs分为3种模式 :1:lvs-nat:本质是多目标IP的DNAT,通过将请求报文中的目标地址和目标端口修改为某挑出的RS的RIP和PORT实现转发(1)RIP和DIP必须在同一个IP网络,且应该使用私网地址;RS的网关要指向DIP(2)请求报文和响应报文都必须经由Director转发,Director易于成为系统瓶颈(3)支持端口映射,可修改请求报文的目…

    2017-10-23
  • Linux运维之路-Linux基础学习二

    Linux系统的一切皆文件思想会帮助我们学习

    2017-11-18
  • class12 shell编程(四)软件包管理(二)

    一、shell编程(四) 1、循环特殊用法 while 循环的特殊用法(遍历文件的每一行): while read line; do       循环体   done < /PATH/FROM/SOMEFILE 依次读取/P…

    Linux干货 2016-08-24