释伴:Linux 上的 Shebang 符号(#!)

本文介绍Shebang(#!)符号在Unix/Linux系统中的作用与历史,包括其命名由来、执行原理及不同情况下的行为表现。

使用Linux或者unix系统的同学可能都对#!这个符号并不陌生,但是你真的了解它吗?

本文将给你简单介绍一下Shebang(”#!”)这个符号。

这个符号(#!)的名称,叫做”Shebang”或者”Sha-bang”。长期以来,shebang都没有正式的中文名称。Linux中国翻译组的 GOLinux 将其翻译为:释伴,即解释伴随行的简称,同时又是shebang的音译。

词源与历史

Shebang的名字来自于SHArp和bang,或haSH bang的缩写,指代Shebang中#!两个符号的典型Unix名称。 Unix术语中,井号通常称为sharphashmesh;而叹号则常常称为bang。也有看法认为,shebang名字中的sh来自于默认shell Bourne shell的名称,sh,因为常常使用shebang调用之。

在2010年版的Advanced bash scripting guide(revision 6.2)中,shebang被称为"sha-bang",同时提到"也写作she-bang或sh-bang",但该文件中没有提到"shebang"这一形式。

丹尼斯·里奇在被问及他会如何称呼这一特性时,他答道:

发信人:"Ritchie, Dennis M (Dennis)** CTR **" <dmr@[redacted]>

收信人:<[redacted]@talisman.org>

日期:Thu, 19 Nov 2009 18:37:37 -0600

主题:RE: What do -you- call your #!<something> line?

我不记得我们曾经给它取过一个适当的名字。导入这一特性已经是相当晚了--我觉得我是从关于伯克利Unix的UCB会议上的某人那里得到的这一灵感;我可能是首先实现它的人之一,但这个创意是来自于别人的。

至于它的名字:可能是类似于"hash-bang"的英国风描述性文字,但我没有在任何场合使用类似宠物的名字来描述它。

此致,

Dennis

用途

Shebang这个符号通常在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。

 from: 

http://smilejay.com/2012/03/linux_shebang/



Linux shell 脚本中,若未指定 `#!/bin/bash` 或类似的 shebang 行,将可能导致脚本执行方式的不确定性,并可能带来一系列潜在问题。 ### 执行器的选择 如果没有 shebang 行,系统会使用当前 shell 来解脚本。这意味着如果用户当前的 shell 是 Bash,则脚本将使用 Bash 解执行;如果当前 shell 是 Zsh,则使用 Zsh 解执行。由于不同 shell 的语法和特性存在差异,这可能导致脚本的行为与预期不符。例如,某些 Bash 特有的功能(如数组、条件表达式等)在其他 shell 中可能无法识别,从而引发错误 [^4]。 ### 默认 shell 的依赖性 大多数 Linux 系统默认使用 Bash 作为用户的登录 shell,但这也可能因环境配置而异。例如,在某些系统中,用户的默认 shell 可能被更改为 Zsh 或其他 shell。在这种情况下,缺少 shebang 行的脚本将依赖于用户的当前 shell,导致行为的不一致。例如,Zsh 和 Bash 在某些语法细节上存在差异,可能导致脚本在不同环境中表现不一致 [^2]。 ### 兼容性问题 即使在 Bash 环境中,某些系统可能配置了 `sh` 作为默认 shell,并且 `sh` 可能指向一个更严格的 POSIX shell 实现(如 Dash)。在这种情况下,运行没有 shebang 的脚本可能会导致兼容性问题,因为 Dash 并不支持 Bash 的所有特性。例如,Bash 支持 `[[ ... ]]` 这种增强的条件测试语法,而 Dash 仅支持 `[ ... ]`,这可能导致脚本在 Dash 环境中运行失败 [^2]。 ### 可执行权限与执行方式 即使脚本没有 shebang 行,只要脚本具有可执行权限(如通过 `chmod +x script.sh` 设置),仍然可以通过显式调用解器来执行,例如 `bash script.sh` 或 `./script.sh`。然而,对于 `./script.sh` 这种执行方式,系统仍然需要通过 shebang 行来确定使用哪个解器。如果没有 shebang 行,系统将尝试使用默认的 shell 来执行脚本,这可能导致不可预测的行为 [^4]。 ### 最佳实践 为了避免上述问题,建议在编写 shell 脚本时始终明确指定 shebang 行。例如,使用 `#!/bin/bash` 表示该脚本应使用 Bash 解执行,或使用 `#!/usr/bin/env bash` 以提高可移植性。这样可以确保脚本在不同环境中具有一致的行为,并减少潜在的兼容性问题 [^4]。 ```bash #!/usr/bin/env bash # 示例脚本内容 echo "Hello, World!" ``` ### 脚本维护与可读性 从维护和可读性的角度来看,明确指定 shebang 行也有助于其他开发者或系统管理员快速了解脚本所需的执行环境。这对于调试和移植脚本到其他系统时尤为重要 [^4]。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值