语句块定义成函数约等于别名,定义函数,再引用函数
封装的可重复利用的具有特定功能的代码
法一:
[function] 函数名 {
命令序列
[return x] #使用return或者exit可以显式的结束函数
}
法二:
函数名(){
命令序列
}
法三:
function 函数名 (){
命令序列
}
其中【function】是可选的,表示该函数的功能,这个是可以省略掉的;函数名后面加一个(),里面没有内容;执行的命令放在{}里面;【return x】的作用是当命令序列执行完毕后返回给系统一个值;也可以省略。
函数定义完之后并不会自动执行,需要调用才行,好处在于可以写一段功能代码作为函数,有需要就直接调用
定义的时候哪怕出现语法错误也没关系,不调用就不会报错
当然我们写函数最终目的还是为了调用,为了实现某个功能块
declare -F
#查看当前已定义的函数名
declare -f
#查看当前已定义的函数定义
declare -f func_name
#查看指定当前已定义的函数名
declare -F func_name
#查看当前已定义的函数名定义
直接在脚本里定义函数的代码块后写函数名即可完成调用
示例:
函数名必须是唯一的,如果先定义了一个,再用同样的名称定义第二个,那么第二个会覆盖第一个的功能,所以这里一定要注意不要重名。
return表示退出函数并返回一个退出值,脚本中可以用$?变量表示该值
函数的使用原则:
函数一结束就取返回值,因为$?变量只返回执行的最后一条命令的退出状态码;
退出状态码必须是0~255,超出时值将为除以256取余
实例:
在 shell 中,调用函数时可以向其传递参数。在函数体内部,通过 $n 的形式来获取参数的值,例如,$1表示第一个参数,$2表示第二个参数…即使用位置参数来实现参数传递。
格式:
unset 要删除的函数名
函数在 shell 脚本中仅在当前 shell 环境中有效
shell 脚本中变量默认全局有效
将变量限定在函数内部使用 local 命令
local限定变量在本函数不会影响全局结果就是20
函数调用自己本身的函数
必须要有结束函数的语句,防止死循环
数组是Shell的⼀种特殊变量,是⼀组数据的集合,⾥⾯的每个数据被称为⼀个数组元素。
当前Bash仅支持一维索引数组和关联数组,Bash对数组的大小没有限制。数组中可以存放多个值。初始化时不需要定义数组大小(与 PHP 类似)。与大部分编程语言类似,数组元素的下标由 0 开始。Shell 数组用括号来表示,元素用"空格"符号分割开,在shell语句中,使用遍历数组的时候,数组格式要写成 ${arr[@]} 或 ${arr[*]}。
变量和数组
变量:存储单个元素的内存空间
数组:存储多个元素的连续的内存空间,相当于多个变量的集合
数组名和索引
索引的编号从0开始,属于数值索引
索引可支持使用自定义的格式,而不仅是数值格式,即为关联索引
下标不连续的,称为稀疏格式
1.
2.
3.
4.
#普通数组可以不事先声明,直接使用
declare -a 数组名
#关联数组必须先声明,再使用
declare -A 数组名
数组的数据类型包括:
- 数值型
- 字符型
- 混合型数值加字符
使用" "或' '定义单引号或双引号括起来
echo ${数组名[*]}
echo ${数组名[@]}
@同*
echo ${#数组名[*]}
echo ${#数组名[@]}
echo ${!数组名[@]} #显示下标
echo ${数组名[索引值]} 输出数组索引值对应的元素,索引值为从0开始
索引值从0开始
对数组所有元素进行访问,根据需要对所需要的元素进行操作
格式:
${数组名[@]/查找字符/替换字符}
格式:
unset 要删除的数组名
格式:
数组名[下标]=变量
格式:
数组名[下标]=变量
使用+=进行追加:
格式:
数组名+=(变量1 变量2 ...)
取最大值:
#!/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
类似于气泡上涌的动作,会将数据在数组中从小到大或者从大到小不断的向前移动。
冒泡排序就是对比相邻的两个元素值,如果满足条件就交换元素值,把较小的元素移动到数组前面,把大的元素移动到数组后面(将两个元素的位置交换),这样较小的元素就像气泡一样从底部上升到顶部。
冒泡算法由双层循环实现,其中外部循环用于控制排序轮数,轮数为排序的数组长度减1,因为最后一次循环只剩下一个元素,不需要再进行比较。而内部循环主要用于比较数组内每个相邻元素之间的大小,以确定是否交换位置,对比和交换次数随着排序轮数而减少。
#!/bin/bash
for i in {0..9}
do
a[$i]=$RANDOM
done
l=${#a[@]}
for ((i=1;i
当 $* 和 $@ 不被双引号" "包围时,它们之间没有任何区别,都是将接收到的每个参数看做一份数据,彼此之间以空格来分隔。
但是当它们被双引号" "包含时,就会有区别了:
比如传递了 5 个参数,那么对于"$*"来说,这 5 个参数会合并到一起形成一份数据,它们之间是无法分割的;而对于"$@"来说,这 5 个参数是相互独立的,它们是 5 份数据。