Linux shell编程之创建函数

 

目录

创建函数

①函数的语法格式

②返回值

默认退出状态码

使用return命令

使用函数输出

③传递参数

④在函数中处理变量

 


 

前言

函数:起个名字在代码中任何位置使用的代码块,提高脚本开发效率,降低代码重复率

 


 

①函数的语法格式

格式一

function name {

commands

}

 

格式二

name()  {

commands

}

说明:

>>>函数名name是用字母、数字、下划线构成,不能以数字开头,一般以函数功能去命名

        例如验证用户账号密码的函数 "username_password_check"

案例:用两种格式定义并使用函数

 
  1. [bei@localhost test]$ cat func.sh

  2. #!/bin/bash

  3. #the first function

  4. function func_01 {

  5.         echo "This is func_01"

  6. }

  7. #the second function

  8. func_02() {

  9.         echo "This is func_02"

  10. }

  11. #using the function func_01

  12. func_01

  13. #using the function func_02

  14. func_02

  15. [bei@localhost test]$ bash func.sh

  16. This is func_01

  17. This is func_02

案例:函数出现重名时,以最新的函数为准,后续的函数调用都会使用新定义的函数

 
  1. [bei@localhost test]$ cat func.sh

  2. #!/bin/bash

  3. #the first function

  4. function func {

  5.         echo "This is func_old"

  6. }

  7. #the second function

  8. func() {

  9.         echo "This is func_new"

  10. }

  11. #using the function func

  12. func

  13. [bei@localhost test]$ bash func.sh

  14. This is func_new

案例:函数调用要在函数定义之后

 
  1. [bei@localhost test]$ cat func.sh

  2. #!/bin/bash

  3. #using a function before the function definition

  4. func

  5. function func {

  6.         echo "This is a function"

  7. }

  8. [bei@localhost test]$ bash func.sh

  9. func.sh: line 3: func: command not found

注意:如果在函数定义之前使用函数,会收到一条错误消息

 


 

②返回值

>>>bash shell会把函数当成一个小型的脚本,当函数运行结束时会返回一个退出状态码

>>>可以使用三种方式去获取退出状态码

 

默认退出状态码

>>>获取默认退出状态码,即在函数执行完成后,立即获得$?的值,此时获得的是函数最后一条命令的退出状态码

>>>但是默认退出状态码,无法知道函数其他命令是否成功执行

案例

 
  1. [bei@localhost test]$ cat func.sh

  2. #!/bin/bash

  3. function func {

  4.         echo "This is a function"

  5.         haha

  6. }

  7. func

  8. echo "$?"

  9. [bei@localhost test]$ bash func.sh

  10. This is a function

  11. func.sh: line 4: haha: command not found

  12. 127

 

使用return命令

>>>使用return命令可以返回特定的退出状态码,允许指定一个整数来定义函数的退出状态码

案例

 
  1. [bei@localhost test]$ cat func.sh

  2. #!/bin/bash

  3. function func {

  4.         read -p "Enter a value: " value

  5.         echo "doubling the value"

  6.         return $[ $value * 2 ]

  7. }

  8. func

  9. echo "return the value : $?"

  10. [bei@localhost test]$ bash func.sh

  11. Enter a value: 50

  12. doubling the value

  13. return the value : 100

>>>func函数会将变量value的输入值翻倍并返回结果,但是返回值在0~255之间,若大于255,对256取余

 
  1. [bei@localhost test]$ bash func.sh

  2. Enter a value: 300

  3. doubling the value

  4. return the value : 88

 

使用函数输出

案例

 
  1. [bei@localhost test]$ cat func.sh

  2. #!/bin/bash

  3. function func {

  4.         read -p "Enter a value: " value

  5.         echo $[ $value * 2 ]

  6. }

  7. result=`func`

  8. echo "The doubled value : $result"

  9. [bei@localhost test]$ bash func.sh

  10. Enter a value: 50

  11. The doubled value : 100

  12. [bei@localhost test]$ bash func.sh

  13. Enter a value: 300

  14. The doubled value : 600

说明

>>>函数funcecho语句显示计算结果

>>>result=`func`,这个命令将func函数的输出赋给$result变量,而不是查看退出状态码

 


 

③传递参数

>>>bash shell会将函数当成一个小型的shell脚本来对待:

         这就意味着:我们可以像在命令行执行脚本时通过位置参数的方式将参数传递给函数

基本格式

 
  1. function func {

  2.  
  3. $1

  4.  
  5. $2

  6.  
  7. }

  8.  
  9. func parameter1 parameter2

说明:传入$1的值是获取parameter1的值,传入$2的值是获取parameter2的值,而不是获取命令行参数

案例:

 
  1. [bei@localhost test]$ cat func.sh

  2. #!/bin/bash

  3. function func {

  4. echo "the first  function parameter is : $1"

  5. echo "the second function parameter is : $2"

  6. }

  7. echo "the first  script parameter is : $1"

  8. echo "the second script parameter is : $2"

  9. func para1 para2

  10. [bei@localhost test]$ bash func.sh hello world

  11. the first  script parameter is : hello

  12. the second script parameter is : world

  13. the first  function parameter is : para1

  14. the second function parameter is : para2

说明:要区别第一个$1,$2和第二个$1,$2 

          第一个$1,$2是脚本的位置参数,它获取的是命令行的位置参数

          第二个$1,$2是函数的位置参数,它获取的是紧跟在调用函数时,函数名后面的位置参数,即此脚本的最后一条命令

 


 

④在函数中处理变量

>>>变量处理关键点:变量的作用域问题,作用域即为在什么情况下变量可见

>>>在函数中定义的变量和普通变量的作用域是不同的

>>>在函数中,变量可分为两类:全局变量和局部变量

全局变量

   在shell脚本中任何地方都有效的变量(但是shell脚本结束后,变量也会失效,这点与系统的全局变量要区分)

   在脚本的主体部分定义的全局变量,函数中可以调用

   函数中定义的全局变量,在脚本中主体部分可以读取

   默认情况下,在脚本中定义的任何变量都是全局变量

 

局部变量

   函数内部使用变量,在声明前加上local关键词即可成为局部变量

   变量只限于在函数中使用 (当需要在函数内部使用变量时,使用局部变量避免与外部变量弄混)

案例

 
  1. [bei@localhost test]$ cat func.sh

  2. #!/bin/bash

  3. function func {

  4.         local val=10

  5.         val=$[ $val + 1 ]

  6.         echo "the value of \$val is $val in function"

  7. }

  8. read -p "please enter a value: " val

  9. echo "the value of \$val is $val before deal by function"

  10. func

  11. echo "the value of \$val is $val after deal by function"

  12. [bei@localhost test]$ bash func.sh

  13. please enter a value: 1

  14. the value of $val is 1 before deal by function

  15. the value of $val is 11 in function

  16. the value of $val is 1 after deal by function

说明: val=$[ $val + 1 ]这个命令处理的是局部变量val,局部变量val的值10加1得到11,

           而同名的全局变量val并不会被处理,它的值为1,调用完函数后它的值仍为1,这就是使用了local关键字的作用

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值