Shell脚本之函数

函数的作用:

  1. 使用函数可以避免代码重复;
  2. 使用函数可以将一个大的工程分割为若干小的功能模块,代码的可读性更强。

函数的使用方法:

  1. 先定义函数
  2. 再引用函数

定义函数的方法

#格式一: 
 function 函数名 {              //三部分之间都要有空格  
   
 命令序列  

} 
 ​
#格式二:

  函数名 ()   {        //函数名和小括号之间的空格可有可无    

  命令序列 
 
}  ​
  
###### main #####  

#可以在主代码区域直接使用函数名调用函数  

函数名

删除函数unset

格式:  

unset 函数名


[root@yuji sh]# unset hello     //删除函数  
[root@yuji sh]# hello           //删除后无法再调用  bash: hello: 未找到命令...

函数返回值

获得函数返回值的两种方式:

  1. return表示退出函数并返回一个退出值,脚本中可以用$?变量显示该值。
  2. 在函数体中用 echo 输出返回值。并在函数体外使用变量赋值后,可再进一步对函数的返回值进行加工操作。

return

使用原则:

  1. 函数一结束就取返回值,因为$?变量只返回执行的最后一条命令的退出状态码。
  2. 退出状态码必须是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"

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值