目录
函数格式
- 可以带function fun() 定义,也可以直接fun() 定义,不带任何参数
- 参数返回,可以显示加:return 返回,如果不加,将以最后一条命令运行结果,作为返回值(0-255)
格式
[ function ] funname [()]
{
action;
[return int;]
}
示例
#!/bin/bash
# 定义函数
function test(){
echo "这是函数内部打印的!"
}
# 调用函数
test
# 可省略function
test1(){
echo "这也是函数内部打印的呀!!"
}
test1
# 带返回值
function addNum(){
a=1
b=2
c=$((a + b))
echo "a+b=$((a + b))"
return $c
}
addNum
# 获取上个命令的执行结果,无返回值 默认为0 表示执行成功,非0表示 上个命令出错
echo "a+b=$?"
函数传参
- 通过 $n 的形式来获取参数的值
- $10 不能获取第十个参数,获取第十个参数需要${10}。当n>=10时,需要使用${n}来获取参数
#!/bin/bash
# 函数传参
funWithParam(){
echo "第一个参数为 $1 !"
echo "第二个参数为 $2 !"
echo "第十个参数为 $10 !"
echo "第十个参数为 ${10} !"
echo "第十一个参数为 ${11} !"
echo "参数总数有 $# 个!"
echo "作为一个字符串输出所有参数 $* !"
}
funWithParam 1 2 3 4 5 6 7 8 9 34 73
参数处理 | 说明 |
---|---|
$# | 传递到脚本的参数个数 |
$* | 以一个单字符串显示所有向脚本传递的参数 |
$$ | 脚本运行的当前进程ID号 |
$! | 后台运行的最后一个进程的ID号 |
$@ | 与$*相同,但是使用时加引号,并在引号中返回每个参数。 |
$- | 显示Shell使用的当前选项,与set命令功能相同。 |
$? | 显示最后命令的退出状态。0表示没有错误,其他任何值表明有错误。 |