shell第九讲
1、特殊变量
我们之前给大家讲过几个特殊变量了,比如 $0 $1 这些位置变量,还有命令执行状态判断符$?。这些在工作中都是比较常用的,初次之外,再给大家分享几个工作中偶尔会用到的。
1.1、位置参数总数
这个主要是用来打印执行的脚本参数的个数,比如:bash [root@localhost ~]# cat a.sh!/bin/bashecho $1 $2 $3 $4 $5 echo "本次脚本传入的参数个数为: $#" [root@localhost ~]# chmod +x a.sh [root@localhost ~]# ./a.sh 11 22 33 44 55 11 22 33 44 55 本次脚本传入的参数个数为: 5
我们一共传入了5个参数,那么此时 $# 返回给我们的参数个数也是5。
1.2、$@与$*
两者使用上基本是一样的效果,都是表示引用传递给脚本的所有参数(所有的位置参数被看做是一个字符串)。比如:bash [root@localhost ~]# cat a.sh!/bin/bashecho $1 $2 $3 $4 $5 echo "本次脚本传入的参数: $*" echo "本次脚本传入的参数: $@" [root@localhost ~]# ./a.sh 11 22 33 44 55 11 22 33 44 55 本次脚本传入的参数: 11 22 33 44 55 本次脚本传入的参数: 11 22 33 44 55
可以看出来两个特殊变量效果是一样的,他会把我们的所有位置参数被看成是一个字符串然后打印出来。
然而在实际工作中,我们往往使用for循环来遍历每一个位置参数,那么有些人习惯加上给特殊变量加上双引号,那么此时在使用上就会有些区别:bash [root@localhost ~]# cat a.sh!/bin/bashecho "这个是\$的使用方法" for i in "$"; do echo ${i} done echo "下面是\$@的使用方法" for i in "$@"; do echo ${i} done [root@localhost ~]# ./a.sh 11 22 33 这个是$*的使用方法 11 22 33 下面是$@的使用方法 11 22 33 [root@localhost ~]#
看到效果了吗?
可以看到当两个特殊变量加了双引号后,此时$*把参数作为一个字符串整体(单字符串)返回,而$@把每个参数作为一个字符串返回。
上面就是两者的使用区别,大家在使用的过程中多加注意。
1.3、$$使用
这个我们在之前的知识中都给大家分享过了,他表示打印当前进程的PID号,
我们当前都是在shell交互界面来执行命令的,这个shell交互我们也称之为在bash进程上,那么我们查看一下当前bash进程的PID号,比如:
bash [root@localhost ~]# ps aux | grep -e pts/0 | grep -v grep | grep bash root 1505 0.0 0.0 115580 2236 pts/0 Ss Mar23 0:00 -bash
从上面第二列我们看到的是bash进程的PID号是1505,现在我们使用$$来打印看看
bash [root@localhost ~]# echo $$ 1505
此时$$就可以打印出来当前进程的PID号,可以看到也是1505。
1.4、$!使用
$!表示打印出来上一条命令运行在后台进程的PID号。比如:
bash [root@localhost ~]# sleep 10 & [2] 3730 [root@localhost ~]# echo $! 3730
我们使用sleep命令发起一个睡眠10秒的进程并放在后台运行,此时使用$!就可以看到我们上一条命令的后台进程PID号是3730。(当然,在命令结尾处放一个&符号,表示把命令放在当前终端的后台运行,同时也会打印出来此后台进程的PID号)