位置參数变量的作用主要用于脚本的传参。
位置參数变量的名称和作用都是确定不能改变的,但是该变量的内容是可以更改的,也就是变量的值。
位置參数变量如下:
位置参数变量 | 作用 |
---|---|
$n |
n 为数字,$0 代表命令本身,$1-$9 代表(脚本命令后的)第一到第九个参数,十以上的参数需要用大括号包含,如${10} 、${15} 。 |
$* |
这个变量代表命令行中所有的参数,$* 把所有的参数看成一个整体。 |
$@ |
这个变量也代表命令行中所有的参数,不过$@ 把每个参数区分对待。 |
$# |
这个变量代表命令行中所有参数的个数。 |
1、位置参数变量$n
$n
:n
为数字,$0
代表命令本身,$1-$9
代表(脚本命令的)第一到第九个参数,十以上的参数需要用大括号包含,如${10}
、${15}
。(这个是一个典型的向Shell脚本当中传递值的方式)
(1)示例:
# 定义一个shell脚本,简单的计算器,求两个数的和。 [root@Lyl tmp]# vim count.sh # 脚本内容如下: #!/bin/bash # 给num1变量赋值是第一个参数 num1=$1 # 给num2变量赋值是第二个参数 num2=$2 # 变量sum是变量num1加变量num2的(其实上边的num1和num2的定义可以省略) sum=$(($num1 + $num2)) # 注意:执行count.sh脚本后的第一个参数会传递给$1,第二个参数会传递给$2, # 然后$num1和$num2进行求和,再赋值给sum变量。 # 但是Shell中自定义变量的默认类型是字符串类型, # 而我们传入的两个数字类型的变量值,Shell默认都识别为字符串类型。 # 而这个时候我们就需要$(( ))把这个两个字符串类型的数值括起来, # Shell才能知道要进行数值运算,里边的参数都是数值(Shell运算符中会详细讲)。 # 而$( )是括系统命令的,然后把该命令运行的结果,赋值给前面的变量,这个我们要注意。 #打印变量sum的值 echo $sum echo $0 # 执行该脚本 [root@Lyl tmp]# chmod 755 count.sh [root@Lyl tmp]# ./count.sh 22 66 88 ./count.sh
(2)总结:
$1
保存的是执行Shell命令之后的第一个参数,$2
保存的是执行Shell命令之后的第二个参数,$0
代表执行脚本的命令,如上边的./count.sh
。
- 位置參数变量好处。
其作用就是把执行脚本命令后输入的参数,传入到脚本中,使脚本中的变量可以灵活取值。 - 位置參数变量的缺点。
如果是一个普通的Linux用户,该脚本并不是自己写的。当你获得该脚本的时候,你是无法知道需要在脚本后边是否加参数,或者是加什么参数,脚本才能正确运行,是没有任何提示的。
所以用位置參数变量传参,并不适合给普通用户来使用,一般是写的脚本自己用的时候,用的比较多。
提示:
位置參数变量也可以给函数中传参(其实就是自己给自己传值)。
给普通用户的脚本,传参的方式用
read
,会有提示,比较友好,我们之后说明。
2、位置参数变量$*
和$@
$*
:这个变量代表命令行中所有的参数,$*
把所有的参数看成一个整体。
$@
:这个变量也代表命令行中所有的参数,不过$@
把每个参数区分对待。
(1)用法
我们先写一个脚本来展示一下位置参数变量$*
和$@
的用法:
# 定义一个脚本parameter.sh [root@Lyl tmp]# vim parameter.sh # 脚本内容如下: #!/bin/bash # 使用$*代表所有的参数(所有参数整体对待) echo "The parameters $* is:$*" # 使用也代表所有参数(所有参数分开对待) echo "The parameters $@ is:$@" # 执行该脚本 [root@Lyl tmp]# chmod 755 parameter.sh [root@Lyl tmp]# ./parameter.sh 11 22 33 44 The parameters $* is:11 22 33 44 The parameters $@ is:11 22 33 44
我们可以看到位置参数变量$*
和$@
,都把执行脚本命令后边带的参数打印出来了。
(2)区别
位置参数变量$*
和$@
的区别是,$*
把所有参数当作一个整体,而$@
是先把11赋值给$@
,在把22赋值给$@
,以此类推,是分开的。
我们通过下边的例子来说明:
# 我们先简单的来说一下for循环 # 简单的for循环例子 for i in 1 2 3 4 do echo $i done # 说明: # 在in后有几个数或者说是以空格隔开的变量(因为默认都是字符串类型), # in后有几个变量,这个for循环就循环几次。 # 第一次循环,把第一个变量赋值给in前边的变量i,然后进入循环操作。 # 这只是for循环的一种形式,知道流程即可,后边会在详细说明Bash中的for循环。 # do和done就类似于Java中for循环的大括号(先这样理解就可以)。 # 写一个for循环脚本 [root@Lyl tmp]# vim for.sh # 脚本内容如下: #!/bin/bash for i in 1 2 3 4 do echo $i done # 执行该脚本 [root@Lyl tmp]# chmod 755 for.sh [root@Lyl tmp]# ./for.sh 1 2 3 4
示例区别:
# 定义一个脚本param.sh [root@Lyl tmp]# vim param.sh # 脚本内容如下: #!/bin/bash # 定义for循环,in后面有几个值,for会循环多少次, # 注意"S*"要用双引号括起来,每次循环会把in后面的值赋予变量i, # Shell把$*中的所有参数看成是一个整体,所以这个for循环只会循环一次。 for i in "$*" do # 打印变量i的值 echo "循环了"$i done echo "===============" # Shell把$@中的每个参数都看成是独立的,所以“$@"中有几个参数,就会循环几次。 # 注意两个for循环的变量名最好不相同,以示区别。相同也没关系。 for j in "$@" do # 打印变量j的值 echo "循环了"$j done # 执行该脚本 [root@Lyl tmp]# chmod 755 param.sh [root@Lyl tmp]# ./param.sh 11 22 33 44 循环了11 22 33 44 =============== 循环了11 循环了22 循环了33 循环了44
图示:
3、位置参数变量$#
$#
:这个变量代表命令行中所有参数的个数。
示例:
# 定义一个脚本parameter.sh [root@Lyl tmp]# vim parameter.sh # 脚本内容如下: #!/bin/bash # 使用$#代表所有参数的个数 echo "The parameters $# is:$#" # 执行该脚本 [root@Lyl tmp]# chmod 755 parameter.sh [root@Lyl tmp]# ./parameter.sh 11 22 33 44 The parameters $# is:4