LinuxShell脚本――函数
摘要:本文主要学习了Shell中函数的定义和使用。
函数的定义
Shell函数的本质是一段可以重复使用的脚本代码,这段代码被提前编写好了,放在了指定的位置,使用时直接调取即可。
函数定义的语法
Shell函数定义的语法格式如下:
1 function 函数名() { 2 命令 3 return 返回值 4 } 对各个部分的说明:
1 function:Shell中的关键字,专门用来定义函数。 2 return:Shell关键字,专门用在函数中返回一个值,这一部分可以写也可以不写。
{}
函数定义的简化写法
函数定义时也可以不写function关键字:
1 函数名() { 2 命令 3 return 返回值 4 } 如果写了function关键字,也可以省略函数名后面的小括号:
1 function 函数名 { 2 命令 3 return 返回值 4 } 函数调用
和其它编程语言不同的是,Shell函数在定义时不能指明参数,但是在调用时却可以传递参数,并且给它传递什么参数它就接收什么参数。
Shell也不限制定义和调用的顺序,你可以将定义放在调用的前面,也可以反过来,将定义放在调用的后面。
调用函数不传递参数
如果不传递参数,直接给出函数名字即可:
1 函数名
调用函数传递参数
如果传递参数,那么多个参数之间以空格分隔:
1 函数名 参数1 参数2 参数3
函数的返回值
return关键字
在大部分编程语言中,返回值是指函数被调用之后,执行函数体中的代码所得到的结果,这个结果就通过return语句返回。
但是Shell中的return语句表示的是函数的退出状态:返回值为0表示函数执行成功了,返回值为非0表示函数执行出错了。if、while、for等语句都是根据函数的退出状态来判断条件是否成立。
Shell函数的返回值只能是一个介于0~255之间的整数,其中只有0表示成功,其它值都表示失败。
函数执行失败时,可以根据返回值(退出状态)来判断具体出现了什么错误,比如一个打开文件的函数,我们可以指定1表示文件不存在,2表示文件没有读取权限,3表示文件类型不对。
如果函数体中没有return语句,那么使用默认的退出状态,也就是最后一条命令的退出状态。更加严谨的写法为:
1 return $?
$?
获取返回值
想得到函数的处理结果,有两种解决方案:
1)借助全局变量,将得到的结果赋值给全局变量。
$()``
使用举例
1)借助全局变量获取返回值
这种方案的弊端是定义函数的同时还得额外定义一个全局变量,如果我们仅仅知道函数的名字,但是不知道全局变量的名字,那么也是无法获取结果的。
1 #!/bin/bash 2 sum=0 3 function doSum(){ 4 sum=$(($1+$2)) 5 return $? 6 } 7 if doSum 2 3 9 echo "sum = $sum" 10 else 11 echo "error" 12 fi 2)在函数内部使用echo输出结果
$()1 $()``
1 #!/bin/bash 2 function doSum(){ 3 echo $(($1+$2)) 4 return $? 5 } 6 sum=$(doSum 2 3) 7 echo "sum = $sum"