首页 > 系统 > Linux > 正文

Bash Shell 注释多行的几种方法

2019-10-26 18:43:32
字体:
来源:转载
供稿:网友

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_

单行的就不说了,井号#可以搞定.下面说多行的.

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表