# |
注释作用, #! 除外,在参数替换 echo ${PATH#*:} 这里不表示注释, 数制转换, 不表示注释 echo $((2#101011)) |
; |
命令行分隔符, 可以在一行中写多个命令. 例如p1;p2表示先执行p1,再执行p2 |
;; |
连续分号 ,终止 case 选项 |
. . |
隐藏文件前缀 |
. |
命令等价于source, . 表示当前目录 .. 表示上一级目录 正则表达式中作为单个字符匹配 |
"" |
双引号,软转义,其内部只允许出现特定的shell元字符($,`,\):$用于变量值替换、`用于命令替换、\用于转义单个字符 |
'' |
单引号,硬转义,其内部所有的shell元字符、通配符都会被关掉。注意,硬转义中不允许出现'(单引号) |
\ |
反斜杠,转义,去除其后紧跟的元字符或通配符的特殊意义 |
/ |
文件名分隔符, 除法操作 |
` (Esc 下边的按钮) |
后置引用, 命令替换 |
: |
空命令, 等价于 "NOP" : > data.log 等同于 cat /dev/null > data.log |
! |
取反操作符 != 不等于 |
* |
万能匹配符, 正则表达式中 |
? |
正则表达式中, ? 匹配任意单个字符 |
$ |
变量符号 |
() |
命令组, (a=hello; echo $a), 在 () 中的命令列表将作为一个子 shell 来运行. 在() 中的变量, 由于在子shell中, 所以对于脚本剩下的部分是不可用的. |
{xxx,yyy,zzz} |
大括号扩展 |
{} |
代码块. 事实上, 这个结构创建了一个匿名的函数. 但是与函数不同的是, 在其中声明的变量, 对于脚本的其他部分的代码来说还是可见的. |
{}\; |
路径名, 一般都是在 find 命令中使用, 注意; 用来结束find 命令序列的 –exec |
[] |
数组元素, 例如 array[1]=abc 字符范围, 在正则表达式中使用 |
[[]] |
表达式本身放在[] 里 |
(()) |
数学计算扩展 |
>& >>& >> < |
重定向 scriptname < filename从文件filename中获取标准输入 |
<< <<< |
重定向, << 用在"here document", <<< 用在"here string" |
\<, \> |
正则表达式中的单词边界 grep '\<the\>' testfile |
| |
管道, 分析前边命令的输出, 并将输出作为后边命令的输入,例:p1 | p2 将p1的标准输出作为p2的标准输入 |
>| |
强制重定向 |
|| |
逻辑或,前一个命令执行失败后,才继续执行下一个命令。例:p1 || p2 ;若p1执行成功后,不执行p2,反之,才执行p2; |
& |
后台运行命令, 一个命令后边跟一个&, 将表示在后台运行,最大好处是无需等待命令执行结束,就可以在同一命令行下继续输入命令 |
&& |
逻辑与,前一个命令执行成功后,才继续执行下一个命令。例:p1 && p2 ;若p1执行成功后,才执行p2,反之,不执行p2; |
~ |
home目录 |
! |
执行历史记录中的命令,"!$" 符号可以将上一条命令的参数传递给下一条命令参数,"!!"执行上一条命令 |
, |
这个符号常运用在运算当中当做"区隔"用途 |
== |
常在条件判断式中看到,代表 "等于" 的意思。 |
^ |
这个符号在规则表达式中,代表行的 "开头" 位置 |
>/dev/null 2>&1 |
标准输出和标准错误都重定向到了/dev/null |
2>&1 >/dev/null |
意思是把标准错误输出重定向到标准输出后重定向到/dev/null |
1>&2 >/dev/null |
意思是把标准输出重定向到标准错误后重定向到/dev/null |
&> /dev/null |
不管你是啥玩意儿文件描述符,通通重定向到/dev/null |
shell中的特殊符号
shell中的特殊符号