今天给伙伴们分享一下Shell 编程-Shell 函数,希望看了有所收获。
我是公众号「想吃西红柿」「云原生运维实战派」作者,对云原生运维感兴趣,也保持时刻学习,后续会分享工作中用到的运维技术,在运维的路上得到支持和共同进步!
如果伙伴们看了文档觉得有用,欢迎大家关注我的公众号,获取相关文档。爱运维,爱生活。
- Shell 函数的本质是一段可以重复使用的脚本代码,这段代码被提前编写好了,放在了指定的位置,使用时直接调取即可
- 松耦合的概念 代码之间的依赖关系
1、定义函数
- 可以带function fun() 定义,也可以直接fun() 定义,不带任何参数。
# 方法一
function name {
commands
[return value]
}
# 方法二
name() {
commands
[return value]
}
-
function 是 Shell 中的关键字,专门用来定义函数;
-
name 是函数名;
-
commands 是函数要执行的代码,也就是一组语句;
-
return value 表示函数的返回值,其中 return 是 Shell 关键字,专门用在函数中返回一个值;这一部分可以写也可以不写。
-
由 { } 包围的部分称为函数体,调用一个函数,实际上就是执行函数体中的代码。
-
函数的优势
- 方便n次使用,减少代码量,使之方便,整洁。
- 当需要修改里面的重复代码时,只需要修改一次函数即可实现需求;
- 将函数写进文件,需要时直接通过文件调用
f1.sh f2.sh
fu1() fu3()
fu2() fu4()
source f2.sh # f2 没有调用函数
fu1
fu2
fu3
2、调用函数
1、执行不带参数的函数
- 直接输入函数名即可,不需要带括号,
functionName
- 执行函数时,函数名前的关键字function和函数名后面的()均不需要带
- 函数的定义必须要在执行的程序前定义或加载
2、执行带参数的函数
functionName arg1 arg2
- Shell中的位置参数($1/ 2... / 2.../ 2.../#/ ? / ?/ ?/@)均可以做为函数的参数进行传递
- $0比较特殊,仍然是父脚本的名称
- 此时父脚本的参数会临时被函数的参数所掩盖或隐藏
- 函数的参数变量是在函数体内里面进行定义
3、函数的执行总结
- Shell各种程序的执行顺序为:系统别名->函数->系统命令->可执行文件等
- 函数执行时,会和调用它的脚本共享变量,也可以为函数设定局部变量及特殊位置参数
- 在Shell函数里面,return和exit功能类似,区别是return是退出函数,exit则是退出脚本
- return语句会返回一个值给调用函数的程序,exit则会返回一个值给执行当前脚本的Shell
- 如果将函数单独存放为一个文件,在加载时需要使用source或 . 进行加载
- 在函数内部一般使用local定义局部变量,仅在函数体内有效
4、调用函数
[[email protected] ~]# cat testfunction.sh
#!/bin/bash
# first function
function HelloWorld() {
echo "Hello world"
}
# second function
Welcome() {
echo "Welcome to edenluo"
}
# third function
function HelloShell {
echo "Hello Shell"
}
# file functions
HelloWorld # 调用函数
Welcome
HelloShell
[[email protected] ~]# bash testfunction.sh
Hello world
Welcome to edenluo
Hello Shell
5、从文件中调用函数
[[email protected] ~]# cat filefunction.sh
function Sum () {
for((i=1;i<=100;i++))
do
((sum=sum+i))
done
echo '{1..100} sum is :' $sum
}
[[email protected] ~]# cat filefunctionfromfile.sh
#!/bin/bash
path="/root/Test/filefunction.sh"
if [ -f ${path}