就是对代码的封装,通常会完成一个功能,进而出现的一种组织和代码的方式。
函数必须先定义才可以使用
方法一:
函数名() { 函数要实现的功能代码 }
方法二:
function 函数名 () { 函数要实现的功能代码 }
例如:
say_you_say_me(){ echo "我看过很多书,但都没有你好看^_^" }
无参函数调用方法
直接只写函数名即可,需单独一行
say_you_say_me
有参函数调用方法
函数传参时和脚本的传参一样。
函数名 参数1 参数2
# 定义函数 say_you_say_any(){ echo "我看过很多书,但都没有 "$1" 好看^_^" } # 调用函数 say_you_say_any xinyi # 此处xinyi即为函数要传递的参数
执行效果
[root@kube-master function]# sh say.sh 我看过很多书,但都没有 xinyi 好看^_^
在Shell中调用函数时可向其传递参数。在函数体内部通过 $n 的形式来获取参数的值,如:$1 表示第1个参数,$2 表示第2个参数…;当n>=10时,表示为 n , 如 : {n},如: n,如:{10}、${11}
# 定义函数 show_args (){ echo "函数的第一个参数$1" echo "函数的第二个参数$2" echo "函数的所有参数$@" echo '函数中 $0 还是' $0 } # 调用函数 show_args hello world
输出
[root@kube-master function]# sh func-args.sh 函数的第一个参数hello 函数的第二个参数world 函数的所有参数world 函数中 $0 还是 func-args.sh
这里要说明一点:在函数被调用前函数是不会被执行的,脚本也不会检查其语法,直到被调用
f1(){ echo "f1...." } function f2(){ f1 echo "f2..." } f2
输出
[root@kube-master function]# sh func.sh f1.... f2...
src_path=$1 target_path=$2 backup(){ echo "源数据目录是 $src_path" echo "源数据目录是 $target_path" } backup
作业:
编写系统初始化脚本
配置YUM
安装 bash-completion epel-release lsof
关闭 selinux
关闭 firewalld
配置静态 IP
按q键退出程序
编写系统管理工具箱
查看内存的使用情况
查看磁盘的使用情况
查看系统的负载
查看目前登录的用户数量
按q键退出程序