Shell脚本注释的实现(在shell脚本中,如何写入注释框)全程干货

随心笔谈2年前发布 admin
164 0 0

文章摘要

这篇文章介绍了shell脚本中注释的实现方法,重点讨论了以下内容: 1. **空命令(:)** 和追加输入重定向(<<) 的结合使用,可以将输入直接注释化,避免执行命令。这种方法特别适用于注释代码中包含变量引用或反引号的情况。 2. 解决注释中有反引号问题的方法,包括: - 方法一:将追加输入重定向与单引号结合,如`:<<BLOCK'...BLOCK'` - 方法二:使用`'...`替换反引号 - 方法三:使用EOF替代反引号 3. 空命令(:) 在if...then语句中的应用,用于什么也不做的命令,如: ```bash if [ -d $DIRECTORY ]; then : else echo 'the directory does not exist!' fi ``` 4. 进一步扩展知识包括Here Documents的使用方法,如通过定义符号WORD或块名BLOCK来注释代码内容。 文章总结了shell脚本注释的多种实现技巧,并提供了实用的解决方案,帮助用户更好地处理注释中可能出现的问题。



目录单行注释多行注释/段注释一、空命令 : 和追加输入重定向 <<二、空命令 : 和 if…then… 语句三、空命令 : 和单引号 ’

直接在行最前端加上符号 # 即可。具体用法如下所示:

# this is comment test
echo “this is comment test”
:<<BLOCK

….注释内容

BLOCK

说明:

把输入重定义(<<)到前面的命令,但是 : 是空命令,所以就相当于注释了。这种方法当注释代码里出现变量引用或者是反引号的命令时,shell 会去尝试解析,会提示错误信息,反引号部分不会被注释掉。

例如:

var=`ls -l` # 这个就不会被注释掉,因为有反引号

BLOCK 为 Here Documents 中的定义符号,名称任意,只要前后匹配就行,如下两个例子中分别使用 WORD 和 _a_ 也可以:

例(1):

:<<WORD

….注释内容

WORD?

例(2):

下面的 :<<_a_ 和 _a_ 代表段注释,可以把中间的代码注释掉,_a_ 为 Here Documents 中的定义符号,名称任意,只要前后匹配就行。

for ((i=0; i<10; i++))
do
:<<_a_ ? ?
? ? if [ ?]; then?
? ? ? ? …
? ? fi
_a_
? ? echo “”
done

常用来作为注释的成对字符有:

EOF、_a_、WORD、BLOCK、!

备注:

EOF 截止符用作后续输入命令! 叹号一般作为嵌入内容部分’ 单引号一般用来区分内容

解决注释中有反引号的问题

方法一

:<<BLOCK’
….注释内容
‘BLOCK

方法二

:<<‘BLOCK
….注释内容
BLOCK’

方法三

:<<‘
….注释内容

方法四

:<<\EOF
注释的代码…
EOF

方法五

:<<‘EOF’
注释的代码…
EOF

: 就是什么也不做(do nothing)即空命令,一般用在 if…then… 条件中,用作什么也不做的命令,如下:

if [ -d $DIRECTORY ]; then
? ? :
else
? ? echo ‘the directory do not exit !’
fi

扩展知识:

下面的例(1)是 Here Documents 的用法,意思是将定义符 WORD 传给某脚本或命令。WORD 的内容为两个 WORD 间输入任意内容,这样就可以在脚本中用 cmd 来执行输入而不必再重建一文件。

例(1):

cmd<<WORD
any input
file content
WORD

Here Documents 常用在菜单屏幕中,看例(2):

例(2):

cat <<Menu
1.List
2.Help
3.Exit
Menu

注意:单引号 ‘ 和冒号 : 之间要加空格。

# echo is test
echo “test”
echo “test”
echo “test”
echo “test”
echo “test” ?
: ‘
echo “comment”
echo “comment”
echo “comment”
echo “comment”
echo “comment”
echo “comment”

到此这篇关于Shell脚本注释的实现的文章就介绍到这了,更多相关Shell脚本注释内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:Shell脚本注释写法

© 版权声明

相关文章