偷偷学习shell脚本之函数
作者:互联网
目录
一、Shell函数
- 函数的作用就是把程序里需要多次使用的部分代码列出来,然后为这部分代码起个名字,其它所有的重复调用这部分代码都只用调用这个名字就可以(类似于别名)。当需要修改这部分重复代码时,只需要改变函数体内的一份代码即可实现调用修改。
- 函数的优点
- 把相同的程序段定义成函数,可以减少整个程序的代码量。
- 增加程序的可读性,以及便于管理。
- 修改时只需要修改函数内就可,不需要在程序里到处找需要修改的地方
二、Shell函数格式
函数格式一:
function 函数名 {
命令序列
}
函数格式二:
函数名() {
命令序列
}
调用函数格式一:直接调用
函数名
调用函数格式一:赋值再输出
result=`函数名`
echo "想要输出的结果"
三、函数返回值
1、return
- return表示退出函数并返回一个退出值,脚本中可以用 $ ? 变量显示该值
- 使用原则
- 函数一结束就取返回值,因为$?变量只返回执行的最后一条命令的退出状态码
- 退出状态码必须是0~255,超出时值将为除以256取余
#!/bin/bash
function cheng {
read -p "请输入:" shu
return $[$shu * 2]
}
cheng
echo $?
2、echo
- echo可以返回任何字符串结果
- 通常用于返回数据,例如:字符串值或列表值
#!/bin/bash
function cheng {
read -p "请输入:" shu
echo $[$shu * 2]
}
cheng
四、函数传参
- 传参就是将主体代码内的参数传到函数体内,一般使用位置参数$n($1、$2、$3…)
#!/bin/bash
sum() {
s=$[$1 + $2]
echo $s
}
read -p "请输入第一个参数:" first
read -p "请输入第二个参数:" second
sum $first $second
五、函数变量的作用范围
- 函数在Shell脚本中仅在当前Shell环境中有效
- Shell脚本中变量默认全局有效
- 将变量限定在函数内部使用local命令
#!/bin/bash
Part() {
echo "这是内部第一个i的值:$i"
i=10
echo "这是内部第二个i的值:$i"
local i=15
echo "这是内部第三个i的值: $i"
}
i=5
echo "这是外部i的值:$i"
Part
echo "这是函数执行完i的值$i
六、递归
- 函数调用自己本身的函数
1、阶乘
- 一个正整数的阶乘是所有小于及等于该数的正整数的积
fact() {
if [ $1 -eq 1 ]
then
echo 1
else
local temp=$[$1 - 1]
local result=$(fact $temp)
echo $[$1 * $result]
fi
}
read -p "请输入:" n
result=$(fact $n)
echo $result
2、递归目录
- 显示本目录下的所有目录和文件(包含子目录下的目录和文件)
#!/bin/bash
list_files () {
for f in `ls $1`
do
if [ -d "$1/$f" ]
then
echo "+$2$f"
list_files "$1/$f" " $2"
else
echo "-$2$f"
fi
done
}
list_files "/var/log" ""
3、创建库
-
创建库,其实就是将重复用的代码规整到一起,这个文件中不含主体代码
-
建立库
#!/bin/bash
jiafa() {
echo $[$1 + $2]
}
jianfa() {
echo $[$1 - $2]
}
chengfa() {
echo $[$1 * $2]
}
chufa() {
if [ $2 -ne 0 ];then
echo $[$1 / $2]
else
echo "$2不能为0"
fi
}
- 调用库运算
#!/bin/bash
. /root/test/ku1.sh
read -p "输入第一个参数值:" first
read -p "输入第二个参数值:" second
result1=`jiafa $first $second`
result2=`jianfa $first $second`
result3=$(chengfa $first $second)
result4=$(chufa $first $second)
echo "相加结果:$result1"
echo "相减结果:$result2"
echo "相成结果:$result3"
echo "相除结果:$result4"
标签:bin,Shell,函数,read,echo,偷偷,second,shell 来源: https://blog.csdn.net/weixin_51326240/article/details/111590059