您的位置:首页 > 博客中心 > 互联网 >

函数与参数

时间:2022-05-11 08:49

前言:

? 函数和别名乍一看很相似,不过两者在行为上还是略有不同。最大的差异在于函数参数可以在函数体中任意位置上使用,而别名只能将参数放在命令尾部;

? 函数的定义包括function命令、函数名、开/闭括号以及包含在一对花括号中的函数体;

1.函数的定义:

function fname()
{
statements;
}

或者

fname()
{
statements;
}

甚至是这样(对于简单的函数):

fname() { statement; }

2.函数的执行

$fname;#执行函数

3.函数参数的传递

fname arg1 arg2 ;  #传递参数

以下是函数fname的定义。在函数fname中,包含了各种访问函数参数的方法。

fname()
{
echo $1, $2; #访问参数1和参数2
echo "$@"; #以列表的方式一次性打印所有参数
echo "$*"; #类似于$@,但是所有参数被视为单个实体
return 0; #返回值
}

传入脚本的参数可以通过下列形式访问。

$0是脚本名称。
$1是第一个参数。
$2是第二个参数。
$n是第n个参数。
"$@"被扩展成"$1" "$2" "$3"等。
"$*"被扩展成"$1c$2c$3",其中c是IFS的第一个字符。
"$@"要比"$*"用得多。由于"$*"将所有的参数当作单个字符串,因此它很少被使用。

4.递归函数

在Bash中,函数同样支持递归调用(可以调用自身的函数)。例如,

F() { echo $1; F hello;sleep 1; }

Fork炸弹

递归函数是能够调用自身的函数。这种函数必须有退出条件,否则就会不断地生成自身,直到系统耗尽所有的资源或是崩溃!

:(){ :|:& };:

这个函数会一直地生成新的进程,最终形成拒绝服务攻击。函数调用前的&将子进程放入后台。这段危险的代码能够不停地衍生出进程,因而被称为Fork炸弹。

5.导出函数

函数也能像环境变量一样用export导出,如此一来,函数的作用域就可以扩展到子进程中:

首先在命令行制定一个函数

catfile(){ ls /tmp/$1}

将函数直接导入脚本文件中

echo "catfile file.txt" >> test.sh

尝试运行脚本

sh test.sh

会报找不到函数的错误。这时候导入函数到环境变量,再次执行

export -f catfile
sh test.sh    #发现可以执行

6.读取命令返回值(状态)

命令的返回值被保存在变量$?中。

当输入一个命令时,命令是否执行成功会返回一个返回值,返回值被称为退出状态它可用于确定命令执行成功与否。如果命令成功退出,那么退出状态为0,否则为非0。

7.向命令传递参数

大多数应用都能够接受不同格式的参数。假设-p、-v是可用选项,-k N是另一个可以接受数字的选项,同时该命令还要求使用一个文件名作为参数。那么,它有如下几种执行方式:

$ command -p -v -k 1 file
$ command -pv -k 1 file
$ command -vpk 1 file
$ command file -pvk 1

在脚本中,命令行参数可以依据其在命令行中的位置来访问。第一个参数是$1,第二个参数是$2,以此类推。
下面的语句可以显示出前3个命令行参数:

echo $1 $2 $3

更为常见的处理方式是迭代所有的命令行参数。shift命令可以将参数依次向左移动一个位置,让脚本能够使用$1来访问到每一个参数。下面的代码显示出了所有的命令行参数:

$ cat showArgs.sh
for i in `seq 1 $#`
do
echo $i is $1
shift
done
$ sh showArgs.sh a b c
1 is a
2 is b
3 is c

本类排行

今日推荐

热门手游