Natural

 

shell 注释多行方法

由于Shell不支持直接多行注释,总结了以下Shell注释多行的变通方法


一、通过Here Documents和:实现
1、最简单方法
:<<BLOCK
注释内容
BLOCK
      把输入重定义到前面的命令,但是:是空命令,所以就相当于注释了。
      如果注释中有反引号的命令就会报错。反引号部分没被注释掉,例如ab=`ls -l abc`就不会被注释掉。
2、解决注释中有反引号的问题
      在windows的cygwin环境中测试时报错
A、方法一
:<<BLOCK'
注释内容
'BLOCK
B、方法二
:<<BLOCK'
注释内容
'BLOCK
C、方法三
:<<'
注释内容
'
      以上三种方法都是通过在:<
      BLOCK为Here Documents中的定义符号可以随意起名,只要前后匹配就行了
3、简单说说:指令和Here Documents
      :就是什么也不作(do nothing)即空命令。它的最基本作用就是在if,then条件中。在if语句中各部分必须接执行命令,但有时你不在乎条件是为真(或假)只在乎相反情况。
command<<word
any input
file content
word
      是Here Documents的用法,意思是将以上的定义符(word,也可以理解成本地文档名)传给某脚本或命令,word的内容为两个word间输入任意内容(word为Here Documents中的定义符号可以随意起名,只要前后匹配就行了),这样就可以在脚本中用command来执行输入而不必再重建一文件。
  常用在菜单屏幕中,例如:
cat <<Menu
  1. List files
  2.HELP
  3.exit
Menu
 
:<<word
....注释内容
word
      就类似于建一本地文件,然后对它执行空命令,也就是什么也不做,就相当于注释了。
  更详细的Here Document说明可参考http://www.tsnc.edu.cn/default/tsnc_wgrj/doc/abs-3.9.1_cn/html/here-docs.html


二、通过循环实现
1、while和:实现
while : 
do 
break
注释内容
done
 
2、until和:实现
until :
注释内容
done
cygwin中测试时报错,要按照如下格式
until :
do
注释内容
done

3、if和:实现
if [ 1 -eq 2 ]
then
注释内容
fi
 
      注意注释内容中是否含”done/fi”,包含会造成意外结束

三、其它方法
1、方法一
: :||:<<\COMMENTS
....注释内容
COMMENTS
  高手说上面这种方法最好,因为Here Documents部分不会执行到,只会分析到,应该不会对第二个:作实际的IO重定向。
2、方法二
: << 'BLOCK'
....注释内容
BLOCK
  可以将里面的变量扩展关闭掉。
3、方法三
:||{
....注释内容
}
  这种方法不用到Here Documents,不过这种方法要注意注释内容中的}
4、方法四
:<<\EOF
....注释内容
EOF
  上面方法可关掉Here Documents中的扩展功能,在Here-Document中忽略ending marker前的任何字符
  实际上使用<<\EOF <<'EOF',甚至<<<\eof在语法上面更加的简洁。不过这种方法同样要注意注释内容中的eof< p=""> <<\eof在语法上面更加的简洁。不过这种方法同样要注意注释内容中的eof<>

四、参考资料
  http://bbs.chinaunix.net/viewthread.php?tid=1152658&extra=&page=1
  http://blog.csdn.net/magicpang/archive/2009/04/14/4072878.aspx
  http://bbs.chinaunix.net/viewthread.php?tid=1196678&extra=&page=1





posted on 2012-03-09 17:36 此号已被删 阅读(2887) 评论(0)  编辑  收藏 所属分类: Linux


只有注册用户登录后才能发表评论。


网站导航:
 

导航

统计

常用链接

留言簿(8)

随笔分类(83)

随笔档案(78)

文章档案(2)

相册

收藏夹(7)

最新随笔

搜索

积分与排名

最新评论

阅读排行榜

评论排行榜