一、Linux脚本第一行
我们在 linux 里面的脚本上,常常会看到这些脚本前面会有 “#!/xxx” 这样一行东西,
比如:
#!/bin/sh
#!/usr/bin/python
#!/usr/bin/env
那么,这行东西是什么来由呢?
二、 sha-bang
可以在2010年版的 Advanced bash scripting guide(revision 6.2)中,找到 #! 的相关说明
其中,Chapter 2. Starting Off With a Sha-Bang 详细解释了 “#!/xxx” 的用法。
sha-bang 这个符号通常在 Unix 系统的脚本中第一行开头中写到,它指明了执行这个脚本文件的解释程序:
1、如果脚本文件中没有 #! 这一行,那么它执行时会默认用当前 Shell 去解释这个脚本(即:$SHELL 环境变量)。
2、如果 #! 之后的解释程序是一个可执行文件,那么执行这个脚本时,它就会把文件名及其参数一起作为参数传给那个解释程序去执行。
3、如果 #! 指定的解释程序没有可执行权限,则会报错“bad interpreter: Permission denied”。如果#!指定的解释程序不是一个可执行文件,那么指定的解释程序会被忽略,转而交给当前的 shell 去执行这个脚本。
4、如果 #! 指定的解释程序不存在,那么会报错 “bad interpreter: No such file or directory”。注意:#!之后的解释程序,需要写其绝对路径(如:#!/bin/bash),它是不会自动到 $PATH 中寻找解释器的。
5、当然,如果你使用 bash test.sh 这样的命令来执行脚本,那么#!这一行将会被忽略掉,解释器当然是用命令行中显式指定的 bash。
6、使用 #!/usr/bin/env 这样的脚本解释器名称,可以实现在不同平台上都能正确找到解释器。
7、如果脚本文件是以 UTF-8 的 BOM(0xEF 0xBB 0xBF) 开头的,那么 exec 函数将不会启动 sha-bang 指定的解释器来执行该脚本。因此,Linux 的脚本文件不应在文件开头包含 UTF-8 的 BOM。
三、其他称呼
#! 除了 sha-bang 的称呼以外,也叫 hash-bang 或者 shebang
1、 hash-bang 出自 丹尼斯·里奇 的邮件
丹尼斯·里奇在被问及他会如何称呼这一特性时,他答道:
发信人:“Ritchie, Dennis M (Dennis)** CTR **”<dmr@[redacted]>
收信人:<[redacted]@talisman.org>
日期:Thu, 19 Nov 2009 18:37:37 -0600
主题:RE: What do -you- call your #! line?我不记得我们曾经给它取过一个适当的名字。导入这一特性已经是相当晚了–我觉得我是从关于伯克利Unix的UCB会议上的某人那里得到的这一灵感;我可能是首先实现它的人之一,但这个创意是来自于别人的。
至于它的名字:可能是类似于"hash-bang"的英国风描述性文字,但我没有在任何场合使用类似宠物的名字来描述它。此致, Dennis
2、shebang 则由 hash-bang 演化而来,相当于是 hash-bang 的缩写了
也有看法认为,shebang 名字中的 sh 来自于默认shell Bourne shell 的名称 sh
另外,在 Unix 术语中, # 号通常称为 sharp,hash 或 mesh;而叹号则常常称为 bang。
也许是在这种称呼背景下, #! 才有这么多种称呼吧。
四、中文名
shebang 长期都是没有正式的中文名称的;
不过 Linux 中国翻译组的 GOLinux 将其翻译为:释伴,即解释伴随行的简称,同时也是 shebang 的音译。