Bash Shell 注释多行的几种方法
1、最简单方法
:<<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
下面的例子:
cmd<<word
any input
file content
word
是 here documents 的用法,意思是将以上的定义符word传给某脚本或命令。
word的内容为两个word间输入任意内容,这样就可以在脚本中用 cmd 来执行输入而不必再重建一文件。
here documents 常用在菜单屏幕中,例如:
cat <<menu
1.list
2.help
3.exit
menu
至于
:<<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... 条件中,用作什么也不做的命令,如:
if [ -d $directory ]; then
:
else
echo 'the directory do not exit !'
fi
如果注释中有反引号的命令就会报错,反引号部分不会被注释掉,例如 var=`ls -l` 就不会被注释掉。
解决注释中有反引号的问题
:<<_a_'
....注释内容
'_a_
单行的就不说了,井号#可以搞定.下面说多行的.
一. 通过here documents实现:
1)
:<<eof
注释的代码...
eof
冒号:表示什么都不做.
说明: 这种方法当注释代码里出现变量引用或者是反引号时,bash会去尝试解析他们,会提示错误信息. 解决方法有下面几种:
1.
:<<\eof
注释的代码...
eof
2.
:<<'eof'
注释的代码...
eof
3.
:<<'eof
注释的代码...
eof'
4.
:<<eof'
注释的代码...
'eof
5.
:<<'
注释的代码...
'
上一篇: 聚来宝是什么意思?聚来宝是真的吗?