TranslateProject/published/202310/20231010 How to Add Comments in Bash Scripts.md
2023-11-01 21:54:16 +08:00

187 lines
6.6 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

[#]: subject: "How to Add Comments in Bash Scripts"
[#]: via: "https://itsfoss.com/bash-comments/"
[#]: author: "Sagar Sharma https://itsfoss.com/author/sagar/"
[#]: collector: "lujun9972/lctt-scripts-1693450080"
[#]: translator: "geekpi"
[#]: reviewer: "wxy"
[#]: publisher: "wxy"
[#]: url: "https://linux.cn/article-16298-1.html"
如何在 Bash 脚本中添加注释
======
![][0]
> 你有要说明的地方吗?请将它们添加到你的 Bash 脚本中。
在 Bash 脚本中添加注释是保持代码整洁且易于理解的最有效方法之一。
你可能会问为什么。
假设你的脚本包含一个复杂的正则表达式或多个复杂的代码块,在这种情况下,你可以添加注释,以便其他开发人员或你可以了解该代码块的含义。
注释掉部分代码也有助于调试脚本。
在本教程中,我将引导你了解在 Bash 脚本中添加注释的三种方法:
* 单行注释
* 行内评论
* 多行注释
那么让我们从第一个开始。
### Bash 中的单行注释
要添加单行注释,你必须将哈希符号(`#`)放在行的开头并编写注释。
这是一个简单的例子:
````
#!/bin/bash
# This is a comment
echo "Hello, World!"
````
执行时,注释将被忽略,当我执行上面的命令时,它看起来像这样:
![][1]
> 💡 `#` 注释规则的唯一例外是脚本开头的 `#!/bin/bash` 行。它称为 [释伴][2],用于指定运行脚本时要使用的解释器。有不同的 Shell语法也可能不同。因此一个好的做法是指定脚本是为哪个 Shell 编写的。例如,如果是 ksh则可以使用 `#!/bin/ksh`.
### Bash 脚本中的内联注释
或者,你可以将注释放在代码块内以记录该特定行的用途。
> 🚧 `#` 之后的任何内容在该行结束之前都不会执行,因此请确保在代码末尾添加注释。
这是一个简单的例子:
````
#!/bin/bash
echo "Hello, World!" #Prints hello world
````
![][3]
### Bash 中的多行注释
> 🚧 Bash 中没有内置的多行注释功能。但是,有一些解决方法可以实现多行注释效果。
顾名思义Bash 脚本中的多行注释允许你在多行中编写注释,或者通过将它们放在多行注释部分来阻止执行代码块:
1. 在每行的开头使用 `#`
2. [冒号表示法][4](使用冒号后跟单引号)
3. 现场文档(使用 `<<` 后跟分隔符)
那么让我们从第一个开始。
#### 1、对块注释的每一行使用 `#`
如果你的目的是解释脚本的一部分,我建议使用此方法。毕竟,`#` 才是真正的注释功能。
这也是许多开发人员使用的方法。
假设你必须在一开始就解释脚本的用途、作者信息或许可信息。你可以这样写:
```
#!/bin/bash
######################################
## This script is used for scanning ##
## local network ##
## Licensed under GPL 2.0 ##
######################################
这个 Bash 脚本的其它部分……
```
当你想说明 Bash 脚本的行为方式时这不错。如果你正在调试 Bash 脚本并希望隐藏部分脚本,则在所需代码的每一行开头添加 `#` 并在调试后将其删除是一项耗时的任务。
接下来的两节将帮助你做到这一点。
#### 2、冒号表示法
要使用冒号表示法,请在 `: '` 和结束的 `'` 之间编写块注释,如下所示:
```
#!/bin/bash
: '
This is how you can use colon notation
And this line too will be ignored
'
echo "GOODBYE"
```
当你执行上面的脚本时,它应该只打印 `GOODBYE`
![][5]
#### 3、现场文档
到目前为止,这是在 Bash 中编写多行注释的最流行的方法,你可以使用 `<<` 后跟分隔符(一组用于指定注释开始和结束的字符)。
LCTT 译注:在编程领域,“**here document**” 是一个常见的术语,特指在脚本语言(如 Perl、Bash能够直接在代码内部嵌入并处理一个数据块或文本串的技术。尽管传统上我们将它翻译为“嵌入式文档” 或不翻译,但这个译法似乎并不能完全地体现出原文的感觉和含义。为了让这个概念变得更为直观和易理解,我们建议将 “here document” 翻译为 “**现场文档**”。“现场”相比于“嵌入式”,更好的传达了文档就在代码的当前位置,或代码“现场”的含义。这样的译法也与原文 “here document” 中 “here”这里的含义更为契合。我们希望这个译法能够在未来得到更广泛的使用和认可让编程的世界因语言的精准而变得更美好。PS., 该译法和解释得到了 ChatGPT 的建议和生成。)
使用方法如下:
```
#!/bin/bash
<<DELIMITER
Comment line 1
Comment line 2
DELIMITER
echo "Hello, World!"
```
还困惑吗? 这是一个简单的例子:
```
#!/bin/bash
<<COMMENT
This is a multi-line comment using a here document.
You can add as many lines as you want between <<COMMENT and the terminating keyword.
This block won't be executed by the shell.
COMMENT
echo "Hello, World!"
```
在上面的示例中,我使用了 `COMMENT` 作为分隔符,但你可以使用任何内容,但要确保它从注释中脱颖而出,否则会造成混乱。
当我执行上面的脚本时,它给出了以下输出:
![][6]
正如你所看到的,它忽略了从 `<<COMMENT``COMMENT` 的所有内容。
我希望本指南对你有所帮助。
*题图MJ/7c2a3ef4-5256-405e-b757-23e0ba1f0bc5*
--------------------------------------------------------------------------------
via: https://itsfoss.com/bash-comments/
作者:[Sagar Sharma][a]
选题:[lujun9972][b]
译者:[geekpi](https://github.com/geekpi)
校对:[wxy](https://github.com/wxy)
本文由 [LCTT](https://github.com/LCTT/TranslateProject) 原创编译,[Linux中国](https://linux.cn/) 荣誉推出
[a]: https://itsfoss.com/author/sagar/
[b]: https://github.com/lujun9972
[1]: https://itsfoss.com/content/images/2023/10/Use-single-line-comments-in-bash.png
[2]: https://linux.cn/article-3664-1.html
[3]: https://itsfoss.com/content/images/2023/10/How-to-use-the-single-line-comments-in-bash.png
[4]: https://stackoverflow.com/questions/3224878/what-is-the-purpose-of-the-colon-gnu-bash-builtin
[5]: https://itsfoss.com/content/images/2023/10/Use-multi-line-comments-using-colon-notation-in-bash.png
[6]: https://itsfoss.com/content/images/2023/10/Use-multi-line-comments-in-bash-using----and-delimeter.png
[7]: https://itsfoss.com/content/images/size/w256h256/2022/12/android-chrome-192x192.png
[0]: https://img.linux.net.cn/data/attachment/album/202310/19/113658dld7b9987xa89l99.jpg