目录
(2)函数备份yum线上源,创建yum本地源,清理缓存安装httpd
(1)数组中可以存放多个值。Bash Shell 只支持一维数组(不支持多维数组),初始化时不需要定义数组大小(与 PHP 类似)。
(3)Shell 数组用括号来表示,元素用"空格"符号分割开
(4)在shell语句中,使用、遍历数组的时候,数组格式要写成 ${arr[@]} 或 ${arr[*]}
一.函数
封装的可重复利用的具有特定功能的代码
格式:
方法一:
[function] 函数名 (){
命令序列
[return x] #使用return或者exit可以显式的结束函数
}方法二:
函数名(){
命令序列
}
1.调用方法
(1)查看当前操作系统
#定义函数
#!/bin/bash
os (){
if grep -i -q "CentOS Linux 7" /etc/os-release
then
echo "此操作系统是centos 7"
elif grep -i -q "CentOS Linux 6" /etc/os-release
then
echo "此操作系统是centos 6"
elif grep -i -q "CentOS Linux 8" /etc/os-release
then
echo "此操作系统是centos 8"
fi
}
#调用函数
os
(2)函数备份yum线上源,创建yum本地源,清理缓存安装httpd
2.返回值
函数一结束就取返回值,因为$?变量只返回执行的最后一条命令的退出状态码
退出状态码必须是0~255,超出时值将为除以256取余
注意:图中包含解决大于255的方法
3.传参
在Shell中,调用函数时可以向其传递参数。在函数体内部,通过 $n 的形式来获取参数的值,例如,$1表示第一个参数,$2表示第二个参数…即使用位置参数来实现参数传递。
4.作用范围
- 函数在Shell脚本中仅在当前Shell环境中有效
- Shell脚本中变量默认全局有效
- 将变最限定在函数内部使用local命令
(1)Shell脚本变量默认全局有效
(2)将变量限定在函数内部
5.递归
函数调用自己本身的函数
二.数组
格式一:
数组名=(value1 value2 ... valuen)
arr_number=(1 2 3 4 5 6 7 8 9)格式二:
数组名=([0]=value0 [1]=value0 [2]=value0 ...)
arr_number=([0]=1 [1]=2 [2]=3 [3]=4)格式三:
列表名:“value1 value2 valueN ..."
数组名=($列表名)
list_number="1 2 3 4 5 6"
arr_number=($list_number)格式四:
数组名[0]="value"
数组名[1]="value"
数组名[2]="value"
arr_number[0]=1
arr_number[1]=2
arr_number[2]=3
1.定义
(1)数组中可以存放多个值。Bash Shell 只支持一维数组(不支持多维数组),初始化时不需要定义数组大小(与 PHP 类似)。
(2)与大部分编程语言类似,数组元素的下标由 0 开始。
(3)Shell 数组用括号来表示,元素用"空格"符号分割开
(4)在shell语句中,使用、遍历数组的时候,数组格式要写成 ${arr[@]} 或 ${arr[*]}
2.显示数组长度
echo ${#数组名[*]}
echo ${#数组名[@]}
3.获取数据列表
echo ${数组名[*]}
echo ${数组名[@]}
4.获取下标对应的值
数组名=(元素0 元素1 元素2 ……) 定义数组
echo ${数组名[索引值]} 输出数组索引值对应的元素,索引值为从0开始
5.常用操作
(1)数组遍历
(2)数组切片
(3)数组替换
(4)删除数组和指定值删除
(4)数组追加
①直接使用下标追加
②将数组长度作为下标追加
③使用+和-追加
(5)declare -a:查看所有数组
三.冒泡排序
#!/bin/bash
#排序之前的数组顺序
a=(10 40 33 30 77 66 44 )
#确定循环比较的次数
for ((j=1;j<${#a[@]};j++))
do
#对比获取每次的最大元素的索引位置
for ((i=0;i<${#a[@]}-j;i++))
do
#如果对比出最大元素,就把该元素赋值给后面的变量tmp
if [ ${a[$i]} -gt ${a[$i+1]} ]
then
#定义一个变量tmp,将每次比较的最大数值放进tmp,实现变量对换
tmp=${a[$i+1]}
a[$i+1]=${a[$i]}
a[$i]=$tmp
fi
done
done
echo ${a[*]}