# | 注释作用, #! 除外,在参数替换 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中的特殊符号
最新推荐文章于 2025-02-26 17:04:35 发布