bash变量类型及区别之浅谈

变量类型,区别

位置变量$0 $1,$2,$# $@ $*

变量的类型:本地变量、环境变量、位置变量

本地变量:生效范围为当前shell进程,对当前shell之外的其他shell进程包括当前shell的子进程均无效

环境变量:生效范围为当前shell进程及子进程

位置变量:$1,…..$n,${10}来表示,用于放脚本在脚本代码中调用通过命令行传递给它的参数



本地变量

变量赋值:name=‘value’,

可以使用引用value:

(1) 可以是直接字串; name=“root"

(2) 变量引用:name="$USER"

(3) 命令引用:name=`COMMAND`, name=$(COMMAND)

变量引用:${name}, $name

"":弱引用,其中的变量引用会被替换为变量值

'':强引用,其中的变量引用不会被替换为变量值,而保持原字符串

显示已定义的所有变量:set

删除变量:unset name

生效范围为当前shell进程,对当前shell之外的其他shell进程包括当前shell的子进程均无效

如下图:

blob.png

编辑一个本地变量:name=mage

echo $mage 可查询变量

 

 blob.png

新开一个窗口再次查询就不显示了,这就是本地变量


blob.png

这里我们写一个小脚本验证一下,

第一行是:shell程序开头的环境指定,这里我们用的是bash

第二行是:一些描述信息;本地变量测试脚本

然后定义var1=success

最后这行是为了方便我们下一步测试,让它把这个变量输出到屏幕上

blob.png

给它执行权限,然后用相对路径运行,然后显示出我们脚本里echo打印的信息;但是用echo $var1却没有。

So:本地变量只针对当前环境有效!




blob.png

我们再建立一个var2的脚本,将var1的变量也写进去

blob.png

没有显示var1的变量。

So:本地变量只对当前环境有效


 

【环境变量】

生效范围为当前shell进程及子进程

显示所有环境变量:

export

env

printenv

删除:unset name

上面我们说过:本地变量只能在当前环境(shell)下使用,

环境变量就是在变量前声明、赋值。加一个字符串:export

blob.png

用之前声明就行

还有一种写法:declare –x 等价于export

练习题:

编写脚本/root/bin/backup.sh,可实现将/etc/目录备份到/root/下生成etcYYYY-mm-dd

20160811 015.jpg

中间的是正文,其他为描述信息

blob.png

有了上下俩行输出信息提示,我们再运行脚本的时候就明白这个脚本是否已经开始和结束了。



位置变量


位置变量:在脚本代码中调用通过命令行传递给脚本的参数

$1, $2, …:对应第1、第2等参数,shift [n]换位置

$0: 命令本身

$*: 传递给脚本的所有参数,全部参数合为一个字符串

$@: 传递给脚本的所有参数,每个参数为独立字符串

$#: 传递给脚本的参数的个数

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


上题,如备份,用起来不灵活,如果我想要备份别的目录呢?或者备份到别的地方呢?

 想要灵活就需要参数

blob.png

 

blob.png

新建f1脚本。 f1的参数作为f2的参数 一个用$*一个用$@ 当我们执行f1.sh脚本的时,f2.sh脚本会调用f1.sh后跟的参数。简单讲就是上一个脚本参数的调用。

结果如下图:

 

 

blob.png

$1(引用第一个参数)打印出来的是全部

$2(引用第二个参数)打印出来的是空

因为$*调用的参数是一个整体(多个字符)

  所以第一个参数就是“a b c d”第二个参数自然就没有了

 

$@调用的参数是单个参数(字符)

 

blob.png

当我们把$*$@的双引号去掉后就没区别了

为被双引号引用时,所有的参数被认为是各个独立的单词

 

第十个参数怎么写?

${10}如果写成$10,系统会认为是$10的组合

blob.png

第十个参数是$10,然后结果是:a0

blob.png

 

blob.png

 

 blob.png

当加上大括号的时候就显示正确了

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

(0)
cszdz123cszdz123
上一篇 2016-08-12
下一篇 2016-08-12

相关推荐

  • net25-第17周作业

    1、结合图形描述LVS的工作原理; lvs-nat模型,相当于多目标的dnat,通过将请求报文中的目标地址和目标端口修改为调度出的rs的rip和port来实现转发,整个请求如下: cip -> vip -> vs(nat转换) -> rip  请求 rip -> dip(默认网关) -> vs(nat转换) ->…

    Linux干货 2017-05-15
  • Buffer和Cache的区别

    1、buffer(缓冲) 是为了提高内存和硬盘(或其他I/O设备)之间的数据交换的速度而设计的。 2、cache(缓存) 从CPU角度考虑,是为了提高cpu和内存之间的数据交换速度而设计的,例如平常见到的一级缓存、二级缓存、三级缓存。 cpu在执行程序所用的指令和读数据都是针对内存的,也就是从内存中取得的。由于内存读写速度慢,为了提高cpu和内存之间数据交换…

    Linux干货 2018-01-02
  • 数据流重导向

    数据流重导向(redirect):就是将某个指令执行后应该要出现在屏幕上的数据,传输到其他的位置。 standard output:标准输出是指指令执行回传正确的讯息。 standard error output : 指令执行失败后,所回传的错误讯息。 1标准输入(stdin):代码为0,使用< <<2标准输出(stdout),代码为1,使…

    Linux干货 2016-08-08
  • Linux 用户、用户组及权限管理

    一、Linux用户及用户组的基本概念 用户:用户是实现能够将有限的资源在多个使用者之间进行分配;、 用户组:用户组是指多个用户的集合,方便对一类需要同样权限的用户授权 Linux是多用户、多任务的操作系统。     多用户指:多人同时使用系统资源;多任务:同时运行多个进程 二、用户及用户组类别 1、用户:名称解析库 /…

    Linux干货 2016-03-20
  • Linux下软链接与硬链接

    Linux下软链接与硬链接的区别 Linux中的文件都文件名和数据,在linux上面被分为两个部分:元数据与数据。用户数据,即文件数据块(data block),数据块是记录文件真实内容的地方,而元数据是文件的附加属性,如大小,创建时间,所有者等信息。在Linux中,元数据中的inode号(inode是文件的元数据的一部分,但其不包含文件名,inode号即索…

    Linux干货 2016-10-20
  • lvm逻辑卷管理

    lvm逻辑卷管理: 允许对卷进行方便操作的抽象层,包括重新设定文件系统的大小 允许在多个物理设备间重新组织文件系统,将设备指定为物理卷 用一个或者多个物理卷来创建一个卷组 物理卷是用固定大小的物理区域(Physical Extent,PE)来定义的 在物理卷上创建的逻辑卷是由物理区域(PE)组成 可以在逻辑卷上创建文件系统 创建: 创建物理卷: pvcrea…

    Linux干货 2016-09-01

评论列表(1条)

  • 马哥教育
    马哥教育 2016-08-12 13:31

    有理论有实践,图文并貌,可以算是不错的笔记,但是,我们写博客是为了给别人看的,可以讲解变量是什么,有哪几类,各类变量的应用场景等。