函数的作用:
- 使用函数可以避免代码重复;
- 使用函数可以将一个大的工程分割为若干小的功能模块,代码的可读性更强。
函数的使用方法:
- 先定义函数
- 再引用函数
定义函数的方法
#格式一:
function 函数名 { //三部分之间都要有空格
命令序列
}
#格式二:
函数名 () { //函数名和小括号之间的空格可有可无
命令序列
}
###### main #####
#可以在主代码区域直接使用函数名调用函数
函数名
删除函数unset
格式:
unset 函数名
[root@yuji sh]# unset hello //删除函数
[root@yuji sh]# hello //删除后无法再调用 bash: hello: 未找到命令...
函数返回值
获得函数返回值的两种方式:
- return表示退出函数并返回一个退出值,脚本中可以用$?变量显示该值。
- 在函数体中用 echo 输出返回值。并在函数体外使用变量赋值后,可再进一步对函数的返回值进行加工操作。
return
使用原则:
- 函数一结束就取返回值,因为$?变量只返回执行的最后一条命令的退出状态码。
- 退出状态码必须是0~255,超出时值将为除以256取余。
示例:
#!/bin/bash
#定义函数
fun1 () {
read -p "请输入一个数字:" num
return $[$num*2]
}
##### main ######
#调用函数
fun1 #输出返回值
echo $?
echo
因为return的返回值的范围是0-255,超过部分除以256取余,得不到我们想要的结果,此时可以直接在函数体中使用echo命令。
示例:
bash复制代码 #!/bin/bash
#定义函数
fun2 () {
read -p "请输入一个数字:" num
echo $[$num*2]
}
##### main ######
#在函数体外使用变量赋值,方便进一步对函数的返回值进行加工操作
result=`fun2`
#输出返回值
echo $result
函数的递归
递归就是一个函数在它的函数体内调用它自身。执行递归函数将反复调用其自身,每调用一次就进入新的一层。所以递归要有两个基本要素,结束条件与递推关系。
递归的两个基本要素:
(1)边界条件:确定递归到何时终止,也称为递归出口。
(2)递归模式:大问题是如何分解为小问题的,也称为递归体。递归函数只有具备了这两个要素,才能在有限次计算后得出结果 。
示例:使用递归计算阶乘
#!/bin/bash
fact() {
#$1表示调用函数时,后面跟的位置参数。如果值是1,就输出1。
if [ $1 -eq 1 ]
then
echo 1
else
#定义一个本地变量temp,变量值为每次传入的参数值减1
local temp=$[$1 - 1]
#不停地调用函数自身,直到temp的值等于1
local result=$(fact $temp)
echo $[$1 * $result]
fi
}
########## main ###########
read -p "请输入一个正整数:" num
a=$(fact $num) echo "$num 的阶乘为:$a"