数组:存放一个或多个元素的连续的内存空间;相当于多个变量的集合

变量:内存的存储空间

变量的特点:每个变量中只能存放一个数据,变量只能进行一次性的赋值

数组元素:数组中任何一个存放数据的存储单元

数组的索引:

 1.数字索引:索引数组(Index ARRAY)

 0,1,2,...

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

 bash4.0以上的版本才支持

稠密数组:索引编号必须连续

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

声明数组:

 1.declare

 -i NAME:将NAME声明为整型变量

 -x NAME:将NAME声明为环境变量

 -a NAME:将NAME声明为索引数组(如果支持)

 -A NAME:将NAME声明为关联数组(如果支持)

 declare -a NAME=("VALUE1" "VALUE2" ...)

 declare -a NAME=([0]="value1" [1]="value2" [5]="value3" ...)

 2.直接声明数组

 直接为数组赋值

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

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

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

 ARRAY_NAME[0]=value1

 ARRAY_NAME[1]=value2   ...

引用数组中的元素

 引用变量的方法:${NAME}

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

注意:如果不给出INDEX,则表示引用数组的第一个元素,即INDEX=0的元素

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

引用数组的索引:$(ARRAY_NAME[*])或者${!ARRAY_NAME[@]}

查看数组的长度(数组中有效元素的个数) 

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

数组切片:

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

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

向数组中追加元素:

 1.稠密数组:

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

 2.稀疏数组:

  ARRAY_NAME[INDEX]=valueN

  注意INDEX必须为未被使用的数组元素索引编号

撤销数组:

 unset ARRAY_NAME

删除数组中的元素:

 unset ARRAY_NAME[INDEX]   

RANDOM变量0-32767

 熵池:/dec/random

     /dev/urando

 随机  

  $[$RANDOM%8+1]这可以生成随机数

bash脚本编程:

shell脚本编程特点

 过程式编程语言

 脚本类语言

 解释型语言

 过程式编程语言:

  顺序执行结构 以从左到右,从上到下顺序执行所有的语句(命令)shell脚本的主体结构

  选择执行结构 依照给定条件的逻辑判断结果或者依照可选的取值范围,进而选择某个分支中的语句来执行  if:分支选择标准逻辑判断的结果   case分支选择标准根据可选的取值

  循环执行结构 对于某特定语句重复执行0次1次或多次

   for:遍历指定的列表

   while:根据逻辑判断的结果;

   until:根据逻辑判断的结果;

   select:永远的死循环,利用循环机制提供选择列表

选择执行结构

if语句

 if 命令; then 命令; [ elif 命令; then 命令; ]... [ else 命令; ] fi

if语句的单分支结构:如果条件为真则执行then后的命令否则不做任何操作;

 if CONDITION

 then STATEMENT

 fi

 if CONDITION;then

  STATEMENT1

  STATEMENT2

 fi

 注意:想要执行then后面的STATEMENTS,前提条件是CONDITION部分为真

if语句的双分支结构:如果条件为真,就执行then后面的命令否则执行else后面的命令

 if CONDITION ; then

  STATEMENT

  ...

 else

  STATEMENT

 fi 

if语句的多分支结构:首先判断CONDITION1是否为真,如果为真,则执行第一个then后面的语句,否则判断CONDITION2是否为真,如果为真,就执行第二个then后面的语句,如果所有的CONDITION都为假,就执行else后面的语句

 if CONDITION1 ; then

  STATEMENT

  ...

 elif CONDITION2 ; then

  STATEMENT 

  ...

 ...

 else

  STATEMENT

  ...

 fi 

 建议if多分支结构能不用就不用

bash脚本编程值用户交互

位置参数变量:$1,$2,$3...

特殊变量

$#:所有的位置参数的总数

$*:所有位置参数的列表,当使用双引号引用时,整个参数被当成一个字符串

$@:所有位置参数的列表,当使用双引号引用时,每个参数作为单独的字符串存在

$0:所执行的脚本文件自身的路径

read:read  [-a 数组] [-p 提示符] [-t 超时]  [名称 ...]

名称一般为变量名或数组名,如果不写名称,则系统会将read读到的信息保存到REPLY变量中

[ -z $NAME1 ] && NAME1=link

注意:在使用read命令的时候,通常会使用-t选项来规定超时时间,一旦使用-t选项定义了超时时间,必须在后面判断给定的变量是否为空,如果为空需要为变量提供变量值

shift [n] 移位位置参数

if语句的多分支结构

循环执行结构

将一段代码重复执行0次1次或多次;

一个好的循环结构,必须包括两个最重要的环节

进入循环的条件

 开始循环时所满足的条件

退出循环的条件

 循环结束所满足的条件

for循环:

 1.遍历列表

  for VAR_NAME in LIST  ; do 循环体 ; done

  for VAR_NAME in LIST  ; do

   循环体

  done

  VAR_NAME:任意指定的变量名称,变量的值是从LIST中取值并赋值的

  循环体:一般来说是能够用到VAR_NAME命令或命令的组合,如果循环体中没有包括VAR_NAME,则可能出现死循环

LIST的生成方式

 1)直接给出

 2)纯整数列表

 seq:输出一个整数列表

 seq [FIRST [INCREMENT]] LAST

 3) 花括号展开{FIRST..LAST}

 4) 命令的执行结果返回值

 5)通配符

 6)某些变量的引用:$@,$*

for循环:

    进入循环的条件:LIST有元素可以取用

    退出循环的条件:LIST中以被取空,在无元素可用

   for循环的特点:

    1.几乎不会出现死循环

    2.在执行循环的过程中,需要将这个LIST载入内存;因此对于大列表来说可能会过多的消耗内存和CPU资源

    注意:使用for循环嵌套的时候,外层for循环,控制行数的输出,内层for循环,控制列表的输出

 2.控制变量

 for ((表达式1;表达式2;表达式3)) ; do

 循环体

 done

 表达式1:为变量赋初始值

 表达式2:循环的退出条件

 表达式3:变量值的变化规律