一、概念和语法

1.作用

1) 概述

shell中的函数类似于命令行的别名,通过把一段代码定义为一个函数体,在其他地方调用该函数时就调用了整段代码。也可以把函数单独的写在一个文件中,当需要调用函数时,再加载进来使用

2) 优势

  • 把相同的程序段定义成函数,可以减少整个程序的代码量,提升开发效率
  • 增加程序的可读性,易读性,提升管理效率
  • 可以实现程序功能模块化,使得持续具备通用性和可移植性

2.语法

1) 标准写法:

1
2
3
4
function 函数名 () {
指令......
return n
}

2) 简化写法

1
2
3
4
函数名 () {
指令......
return n
}

3) 函数的执行

函数分为最基本的函数和可以传参的函数两种,执行方式分别如下:

  • 函数名
  • 函数名 参数1 参数2

函数后接参数的说明:

  1. shell的位置参数($1、2...2、...、#、#*、??及@)都可以作为函数的参数来使用
  2. 此时父脚本的参数临时地被函数参数所掩盖或隐藏
  3. $0比较特殊,它仍然是父脚本的名称
  4. 当函数执行完成时,原理的命令行脚本的参数即可恢复
  5. 函数的参数变量是再函数体里面定义的

3. 函数的重要说明

  • 执行shell函数时,函数名前的function和函数后的小括号都不要带
  • 函数的定义必须在要执行的程序前面定义或加载
  • shell执行系统中的各种程序的顺序:系统别名–>函数–>系统命令–>可执行文件
  • 函数执行时,会和调用他的脚本共用变量,也可以为函数设置局部变量和特殊位置参数
  • shell函数中,return命令的功能和exit类似,return的作用是退出函数,而exit的作用是退出脚本
  • return语句会返回退出值给调用函数的当前程序,而exit会返回一个退出值给执行程序的当前shell
  • 如果将函数存放在独立的文件中,被脚本加载使用时,需要使用source或"."来加载
  • 在函数内一般使用local定义局部变量,这些变量离开函数后就会消失

二、基础实践

1. 最简单函数的创建和调用

  • cat /server/scripts/b3.sh
1
2
3
4
5
6
7
8
9
#!/bin/sh
noahboy () {
echo "this is noahboy"
}
noahgirl () {
echo "this is noahgirl"
}
noahboy
noahgirl
  • sh /server/scripts/b3.sh
    this is noahboy
    this is noahgirl

分别创建了两个函数,然后分别进行了调用,输出结果就输出这两个函数的执行结果

2. 将函数写入系统函数文件中再调用

/etc/init.d/functions文件是linux系统函数库文件,可以先将函数在此文件创建好,然后在脚本中调用该文件就行了,该文件里有很多默认的函数可供调用

  • 先将noahboy函数写入函数文件中
1
2
3
4
5
cat >>/etc/init.d/functions <<EOF
noahboy () {
echo "this is noahboy."
}
EOF
  • 新编写脚本调用并执行
1
2
3
4
5
cat >/server/scripts/b3.sh <<EOF
#!/bin/sh
[ -f /etc/init.d/functions ] && . /etc/init.d/functions || exit 1
noahboy
EOF
  • sh /server/scripts/b3.sh
    this is noahboy.

先判断函数文件存在不,存在的话通过"."加载函数文件,再调用函数

3. 函数传参

1
2
3
4
5
6
7
cat >/server/scripts/b3.sh <<EOF
#!/bin/sh
noahgirl () {
echo "i am olgirl,you are $1"
}
noahgirl $1
EOF
  • sh /server/scripts/b3.sh man
    i am olgirl,you are man

noahgirl中使用参数$1,然后调用函数是也指定了$1,此时执行脚本并且传参时,$1会传递到函数内部执行,所以结果如上