linux命令逻辑符号 linux命令符号解释( 四 )


CDPATH=.:~:/home:/home/web:/var:/usr/local
在上行 CDPATH 的设定中,等号后的 dot 代表的就是当前目录的意思 。
如果档案名称以 dot 开头 , 该档案就属特殊档案 , 用 ls 指令必须加上 -a 选项才会显示 。除此之外,在 regularexpression 中,一个 dot 代表匹配一个字元 。
被单引号用括住的内容,将被视为单一字串 。在引号内的代表变数的 符号 , 没有作用,也就是说,linux命令逻辑符号他被视为一般符号处理 , 防止任何变量替换 。heyyou=homeecho ' heyyou' # We get $heyyou
被双引号用括住的内容,将被视为单一字串 。它防止通配符扩展,但允许变量扩展 。这点与单引数的处理方式不同 。
heyyou=homeecho "$heyyou" # We get home
在前面的单双引号,括住的是字串,但如果该字串是一列命令列,会怎样?答案是不会执行 。要处理这种情况 , 我们得用倒单引号来做 。
fdv=`date +%F`echo "Today $fdv"
在倒引号内的 date +%F 会被视为指令,执行的结果会带入 fdv 变数中 。
这个符号常运用在运算当中当做"区隔"用途 。如下例
#!/bin/bashlet "t1 = ((a = 5 + 3, b = 7 - 1, c = 15 / 3))"echo "t1=t1, a = a, b = $b"
在路径表示时,代表目录 。
cd /etc/rc.dcd ../..cd /
通常单一的 / 代表 root 根目录的意思;在四则运算中,代表除法的符号 。
let "num1 = ((a = 10 / 2, b = 25 / 5))"
在交互模式下的escape 字元 , 有几个作用;放在指令前,有取消 aliases的作用;放在特殊符号前,则该特殊符号的作用消失;放在指令的最末端 , 表示指令连接下一行 。
# type rmrm is aliased to `rm -i'# \rm ./*.log
上例,我在 rm 指令前加上 escape 字元,作用是暂时取消别名的功能,将 rm 指令还原 。
# bkdir=/home# echo "Backup dir, $bkdir =bkdir"Backup dir, bkdir = /home
上例 echo 内的 $bkdir,escape 将变数的功能取消了,因此,会输出 bkdir , 而第二个 $bkdir则会输出变数的内容 /home 。
pipeline 是 UNIX 系统,基础且重要的观念 。连结上个指令的标准输出,做为下个指令的标准输入 。
who | wc -l
善用这个观念,对精简 script 有相当的帮助 。
通常它代表反逻辑的作用,譬如条件侦测中,用 != 来代表"不等于"
if [ "$?" != 0 ]thenecho "Executes error"exit 1fi
在规则表达式中她担任 "反逻辑" 的角色
ls a[!0-9]
上例,代表显示除了a0, a1 .... a9 这几个文件的其他文件 。
在 bash 中,这是一个内建指令:"什么事都不干",但返回状态值 0 。
:
echo $? # 回应为 0
:f.
上面这一行 , 相当于cat/dev/nullf.
。不仅写法简短了,而且执行效率也好上许多 。
有时,也会出现以下这类的用法
: ${HOSTNAME?} ${USER?} ${MAIL?}
这行的作用是,检查这些环境变数是否已设置,没有设置的将会以标准错误显示错误讯息 。像这种检查如果使用类似 test 或 if这类的做法,基本上也可以处理 , 但都比不上上例的简洁与效率 。
除了上述之外,还有一个地方必须使用冒号
PATH=$PATH:$HOME/fbin:$HOME/fperl:/usr/local/mozilla
在使用者自己的HOME 目录下的 .bash_profile或任何功能相似的档案中,设定关于"路径"的场合中,我们都使用冒号,来做区隔 。
在文件名扩展(Filename expansion)上扮演的角色是匹配一个任意的字元 , 但不包含 null 字元 。
# ls a?a1
善用她的特点,可以做比较精确的档名匹配 。
相当常用的符号 。在文件名扩展(Filename expansion)上 , 她用来代表任何字元,包含 null 字元 。

推荐阅读