1、bash shell注释最简单方法
:<<BLOCK
....注释内容
BLOCK
把输入重定义到前面的命令,但是 : 是空命令,所以就相当于注释了。
如果注释中有反引号的命令就会报错,反引号部分不会被注释掉,例如 var=`ls -l` 就不会被注释掉。
2、注释中反引号问题的解决方法
A、方法一
:<<BLOCK'
....注释内容
'BLOCK
B、方法二
:<<'BLOCK
....注释内容
BLOCK'
C、方法三
:<<'
....注释内容
'
BLOCK 为 Here Documents 中的定义符号,名称任意,只要前后匹配就行。
3、: 指令和 Here Documents
: 就是什么也不做(do nothing)即空命令,一般用在 if...then... 条件中,用作什么也不做的命令,如:
if [ -d $DIRECTORY ]; then
:
else
echo 'the directory do not exit !'
fi
例子:
是 Here Documents 的用法,将以上的定义符WORD传给某脚本或命令。
word的内容为两个word间输入任意内容,即可在脚本中用 cmd 来执行输入而不必再重建一文件。
Here Documents 常用在菜单屏幕中,例如:
至于
:<<WORD
....注释内容
WORD
就类似于建一本地文件,然后对它执行空命令,什么也不做,亦即是相当于注释了。
补充:
for ((i=0; i<10; i++))
do
:<<_a_
if [ ]; then
...
fi
_a_
echo ""
done
上面的 :<<_a_ 和 _a_ 代表段注释,可以把中间的代码注释掉
_a_ 为 Here Documents 中的定义符号,名称任意,只要前后匹配就行
: 为空命令,相当于什么都不做(do nothing)即空命令,一般用在 if...then... 条件中,用作什么也不做的命令,如:
如果注释中有反引号的命令就会报错,反引号部分不会被注释掉,例如 var=`ls -l` 就不会被注释掉。
解决注释中有反引号的问题:
:<<_a_'
....注释内容
'_a_
单行井号#可以搞定,以下是多行注释的方法。
一、通过Here Documents实现:
1)
:<<EOF
注释的代码...
EOF
冒号:表示什么都不做.
说明: 这种方法当注释代码里出现变量引用或者是反引号时,bash会去尝试解析他们,会提示错误信息. 解决方法有下面几种:
1.
:<<EOF
注释的代码...
EOF
2.
:<<'EOF'
注释的代码...
EOF
3.
:<<'EOF
注释的代码...
EOF'
4.
:<<EOF'
注释的代码...
'EOF
5.
:<<'
注释的代码...
'