shell脚本-函数与数组

一、函数:

1.函数的作用:

  • 语句块定义成函数约等于别名,定义函数,再引用函数

  • 封装的可重复利用的具有特定功能的代码

2.函数定义的基本格式:

法一:
[function] 函数名 {
	命令序列
	[return x]         #使用return或者exit可以显式的结束函数
}
 
法二:
函数名(){
	命令序列
}
 
法三:
function  函数名 (){
    命令序列
}

其中【function】是可选的,表示该函数的功能,这个是可以省略掉的;函数名后面加一个(),里面没有内容;执行的命令放在{}里面;【return x】的作用是当命令序列执行完毕后返回给系统一个值;也可以省略。

3.函数的注意事项:

函数定义完之后并不会自动执行,需要调用才行,好处在于可以写一段功能代码作为函数,有需要就直接调用
定义的时候哪怕出现语法错误也没关系,不调用就不会报错
当然我们写函数最终目的还是为了调用,为了实现某个功能块

4.查看函数列表:

declare -F
#查看当前已定义的函数名
declare -f
#查看当前已定义的函数定义
declare -f func_name 
#查看指定当前已定义的函数名
declare -F func_name
#查看当前已定义的函数名定义

5.函数调用:

直接在脚本里定义函数的代码块后写函数名即可完成调用

示例:

 函数名必须是唯一的,如果先定义了一个,再用同样的名称定义第二个,那么第二个会覆盖第一个的功能,所以这里一定要注意不要重名。

6.函数的返回值:

return表示退出函数并返回一个退出值,脚本中可以用$?变量表示该值

函数的使用原则:

  • 函数一结束就取返回值,因为$?变量只返回执行的最后一条命令的退出状态码

  • 退出状态码必须是0~255,超出时值将为除以256取余

实例:

7.函数的传参:

在 shell 中,调用函数时可以向其传递参数。在函数体内部,通过 $n 的形式来获取参数的值,例如,$1表示第一个参数,$2表示第二个参数…即使用位置参数来实现参数传递。

8.删除函数:

格式:

unset  要删除的函数名     

9.函数的范围:

  • 函数在 shell 脚本中仅在当前 shell 环境中有效

  • shell 脚本中变量默认全局有效

  • 将变量限定在函数内部使用 local 命令

local限定变量在本函数不会影响全局结果就是20

10.函数的递归:

函数调用自己本身的函数

必须要有结束函数的语句,防止死循环

二、数组:

1.数组的定义:

数组是Shell的⼀种特殊变量,是⼀组数据的集合,⾥⾯的每个数据被称为⼀个数组元素。

当前Bash仅支持一维索引数组和关联数组,Bash对数组的大小没有限制。数组中可以存放多个值。初始化时不需要定义数组大小(与 PHP 类似)。与大部分编程语言类似,数组元素的下标由 0 开始。Shell 数组用括号来表示,元素用"空格"符号分割开,在shell语句中,使用遍历数组的时候,数组格式要写成 ${arr[@]} 或 ${arr[*]}。

变量和数组

变量:存储单个元素的内存空间

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

数组名和索引

索引的编号从0开始,属于数值索引

索引可支持使用自定义的格式,而不仅是数值格式,即为关联索引

下标不连续的,称为稀疏格式

2.定义数组的方法:

1.

2.

3.

4.

3.数组声明:

#普通数组可以不事先声明,直接使用
declare  -a  数组名
 
#关联数组必须先声明,再使用
declare  -A  数组名

4.数组的数据类型:

数组的数据类型包括:

- 数值型
- 字符型
- 混合型数值加字符

使用" "或' '定义单引号或双引号括起来

5.获取数组的数据列表:

echo ${数组名[*]}
echo ${数组名[@]}

@同* 

6.获取数据长度:

echo ${#数组名[*]} 
echo ${#数组名[@]} 
echo ${!数组名[@]}  #显示下标
 
 
echo ${数组名[索引值]}			输出数组索引值对应的元素,索引值为从0开始

索引值从0开始

7.数组的基本使用方法:

7.1 数组元素的遍历:

对数组所有元素进行访问,根据需要对所需要的元素进行操作

7.2数组切片:

7.3 数组替换:

格式:

${数组名[@]/查找字符/替换字符}

7.4 数组删除:

格式:

unset  要删除的数组名

7.5 查看所有数组-declare -a :

8.数组追加替换元素:

8.1 替换:

格式:

数组名[下标]=变量

8.2 追加:

格式:

数组名[下标]=变量

使用+=进行追加:

格式:

数组名+=(变量1 变量2 ...) 

9.取出数组中的最大值和最小值:

取最大值:

#!/bin/bash
read -p "请输入数组:" num
a=($num)
max=${a[0]}
l=${#a[@]}
for ((i=0;i<$l;i++))
do
if [[ $max -lt ${a[$i+1]}  ]]
then
max=${a[$i+1]}
fi
done
echo $max

取最小值:

#!/bin/bash
 
read -p "请输入数组" num
a=($num)
min=${a[0]}
for ((i=0;i<${#a[@]}-1;i++))
do
if [[ $min -ge ${a[$i+1]} ]]
then
min=${a[$i+1]}
fi
done
echo "最小值是$min"

取最大最小值:

#!/bin/bash
for i in {0..9}
do
  a[$i]=$RANDOM
   [ $i -eq 0  ] &&  min=${a[0]}  &&  max=${a[0]}
   [ ${a[$i]} -gt  $max   ] && max=${a[$i]}
   [ ${a[$i]} -lt  $min   ] && min=${a[$i]}
done
 
echo  ${a[@]}
 
echo max=$max
echo min=$min

10.冒泡排序:

类似于气泡上涌的动作,会将数据在数组中从小到大或者从大到小不断的向前移动。

10.1基本思想:

冒泡排序就是对比相邻的两个元素值,如果满足条件就交换元素值,把较小的元素移动到数组前面,把大的元素移动到数组后面(将两个元素的位置交换),这样较小的元素就像气泡一样从底部上升到顶部。

10.2算法思路:

冒泡算法由双层循环实现,其中外部循环用于控制排序轮数,轮数为排序的数组长度减1,因为最后一次循环只剩下一个元素,不需要再进行比较。而内部循环主要用于比较数组内每个相邻元素之间的大小,以确定是否交换位置,对比和交换次数随着排序轮数而减少。

10.3 案例: 

#!/bin/bash
 
for i in {0..9}
do
  a[$i]=$RANDOM
done
 
l=${#a[@]}
for ((i=1;i<l;i++))
do
  for  ((j=0;j<l-i;j++))
  do
   first=${a[$j]}
   k=$[j+1]
   second=${a[$k]}
   if  [[ $first -gt $second ]]
   then
   temp=$first
   a[$j]=$second
   a[$k]=$temp
   fi
  done
done
 
echo ${a[@]}

11.$@和$*区别:

当 $* 和 $@ 不被双引号" "包围时,它们之间没有任何区别,都是将接收到的每个参数看做一份数据,彼此之间以空格来分隔。
但是当它们被双引号" "包含时,就会有区别了:

  • "$*"会将所有的参数从整体上看做一份数据,而不是把每个参数都看做一份数据。
  • "$@"仍然将每个参数都看作一份数据,彼此之间是独立的。

比如传递了 5 个参数,那么对于"$*"来说,这 5 个参数会合并到一起形成一份数据,它们之间是无法分割的;而对于"$@"来说,这 5 个参数是相互独立的,它们是 5 份数据。

  • 23
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值