shell编程-函数
2021/7/15 7:09:19
本文主要是介绍shell编程-函数,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
一、什么是函数
就是对代码的封装,通常会完成一个功能,进而出现的一种组织和代码的方式。
二、函数式编程
- 减少代码重复编写,从而也提高了代码的可复用率。
- 程序逻辑解构清晰。
- 可以使程序代码更易读,便于管理维护。
- 模块化编程思想的基础。
三、函数的定义和调用
1、定义
函数必须先定义才可以使用
方法一:
函数名() { 函数要实现的功能代码 }
方法二:
function 函数名 () { 函数要实现的功能代码 }
例如:
say_you_say_me(){ echo "我看过很多书,但都没有你好看^_^" }
2、调用
无参函数调用方法
直接只写函数名即可,需单独一行
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 好看^_^
四、函数参数
1、介绍
在Shell中调用函数时可向其传递参数。在函数体内部通过 $n 的形式来获取参数的值,如:$1 表示第1个参数,$2 表示第2个参数…;当n>=10时,表示为 n , 如 : {n},如: n,如:{10}、${11}
- 位置参数变量
$n:利用参数向程序中传递需要调用的值n为数字,n≤9直接用数字,n≥10都需要用{}包含:$0 表示命令本身 $1-$9 表示第1-9个参数 ${10} 表示第10个参数 - 特殊变量
$* :表示命令行中所有的参数,所有参数看作一个整体
$@:表示命令行中的所有参数,每个参数区分对待
$#:表示命令行中所有参数的个数(不统计$0) - 预定义变量
$?:最后一次执行的命令所返回的状态:若变量值为0,说明上一个命令正确执行若变量值为非0,说明上一个命令执行不正确
$$:当前进程的进程号(PID)
$! :后台运行的最后一个进程的进程号(PID)
2、示例
# 定义函数 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键退出程序
这篇关于shell编程-函数的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-05Web开发入门指南
- 2024-11-05初学者指南:理解和防范跨域漏洞
- 2024-11-05初学者指南:安全攻防基础教程
- 2024-11-05安全渗透入门:新手必学的渗透测试基础教程
- 2024-11-05初学者指南:渗透测试入门教程
- 2024-11-05渗透攻防入门指南
- 2024-11-05渗透技术入门指南:基础知识与实战演练
- 2024-11-05初学者指南:数据库服务漏洞排查与防范
- 2024-11-05网络攻防入门指南
- 2024-11-05SQL注入入门教程:保护你的数据库安全