shell中的位置参数变量

要了解位置变量,首先要知道什么是变量?

 变量就是让某一个特定的字符串来代表不固定的内容,简单理解就是用一个简单的“字眼”来替代另一个比较复杂或者容易变动的数据。

而什么又是位置变量呢?

 位置变量就是bash将传递给脚本的参数,按照位置不同,保存在不同的位置变量中,以便于脚本调用这些变量。

位置参数变量:

$1, $2, …: 对应第1、第2等参数,shift [n]换位置
$0:  命令本身
$*:  传递给脚本的所有参数,全部参数合为一个字符串;代表“$1$2$3…”
$@:  传递给脚本的所有参数,每个参数为独立字符串;代表“"$1" "$2" "$3" …”
$#:  传递给脚本的参数的个数

    注:$@ ,$* 只在被双引号包起来的时候才会有差异

示例:

编写一个脚本来测试一下上述的位置参数变量:

shell中的位置参数变量

shell中的位置参数变量

这个示例,可以看到位置参数变量,在bash中就实现定义好的,按照位置分配不同的变量。在执行脚本的时候,后面直接跟参数,就会赋予不同的变量,这样在脚本中就可以直接调用。通过示例可以证明,

$N(N表示不同的数字),及可表明第N个参数变量;$0表示命令本身。

注:第十个以上的位置参数变量要使用“{ }”括起来,如:${10}


示例:比较$10和${10}的区别

shell中的位置参数变量

可以看到"$10"表示($1)0;"${10}"才表示第十个位置参数变量.所以10以上的位置参数变量,需要用配合"{ }"来使用。



示例:比较"$*"和"$@"的区别

首先在一个空目录下编写了一个测试脚本,测试过程如图所示:shell中的位置参数变量

可以看到:“touch "$*"”创建了一个名为“aa bb”的文件

而“mkdir "$@"”创建了aa和bb两个目录。

所以,"$*"和"$@"虽然都是表示全部的参数,但是"$*"是把所有的参数当成为一个整体,而"$@"则是把每个参数独立看待

需要注意的是,$*和$@只在被双引号包起来的时候才会有差异。

让我们来看下没有加双引号的情况:

shell中的位置参数变量

如图所示,使用“touch $*”是创建了cc和dd两个文件,而“mkdir $@”因此存在同名文件而没有创建成功,但是通过执行过程也可以看到,它是要创建cc和dd两个目录。所以以后使用"$*"或"$@"时,一定要加上双引号。

还有一个位置参数变量为$#,这个变量表示传递给脚本的参数的个数,让我们来看看如何使用这个变量。

shell中的位置参数变量

可以看到$#表示位置参数的个数,并且在脚本中可以利用"$#"来判断是否存在位置参数

原创文章,作者:Groot,如若转载,请注明出处:http://www.178linux.com/34071

(1)
GrootGroot
上一篇 2016-08-12 16:06
下一篇 2016-08-12 16:06

相关推荐

  • N23 9月底的

    1.linux下文件管理命令 cat 读取文件 或者连接显示touch 建立文件 改变时间 cp 复制文件 -f 强制复制 不论覆盖-r 连同子目录递归处理-l 建立硬链接-s 建立符号连接 rm 删除文件 -r 递归删除 连同子目录也一起干掉-f 强制 删除文件或者目录-d 直接删除目录 file 辨识文件类型 find 查找文件 whereis 查找文件…

    Linux干货 2016-09-25
  • 文件查找命令之locate、find简析

    文件查找命令之locate、find简析    在工作中经常会在文件系统上查找符合条件的文件,今天学习了文件查找命令,在此简析locate和find两个文件查找工具。 一、杂项知识整理 1、find的选项-user的实质是通过UID查找,如果两个用户的UID相同,其会显示两个用户的所有符合条件的文件。 2、查找时-name "*…

    Linux干货 2016-08-15
  • Linux的常用的计划任务(一次任务与周期性任务) at & cron

      在Linux日常维护工作中,维护员不可能每时每刻都守在服务前前,但如果遇到例行的操作要进行怎么办?设定计划任务!     Linux任务计划、周期性任务执行     • 未来的某时间点执行一次任务:      &n…

    Linux干货 2016-09-09
  • Corosync + Pacemaker 搭建高可用MariaDB服务

    Corosync + Pacemaker 搭建高可用MariaDB服务 实验描述 1.本实验的目的是为了通过手动配置corosync配置文件,实现MariaDB服务的高可用,集群心跳传递使用组播方式。2.三个节点的主机名分别为:node5.redhat.com、node6.redhat.com、node7.redhat.com。地址为172.16.100.5…

    Linux干货 2016-04-06
  • N26-第七周博客作业

    一、创建一个10G分区,并格式为ext4文件系统; 1、 要求其block大小为2048, 预留空间百分比为2, 卷标为MYDATA, 默认挂载属性包含acl;          A、创建一个10G的磁盘空间 [root@VM_221_40_centos ~]#fdisk /de…

    2017-07-09
  • Redis应用场景

    1.  MySql+Memcached架构的问题   实际MySQL是适合进行海量数据存储的,通过Memcached将热点数据加载到cache,加速访问,很多公司都曾经使用过这样的架构,但随着业务数据量的不断增加,和访问量的持续增长,我们遇到了很多问题:   1.MySQL需要不断进行拆库拆表,Memcached也需不断跟着扩容,扩容和维护工作占据…

    Linux干货 2016-03-22

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-16 16:21

    总结的很全面,图片清晰明了,完成的很认真,再接再厉!