Linux 在运行文本脚本时如何决定调用哪个解释器

Linux 在运行文本脚本时如何决定调用哪个解释器

有人知道 Linux 在运行文本脚本时如何决定调用哪个解释器吗?我需要“shebang”的细节、目的以及如何进行

答案1

执行脚本有两种主要方式:

  • 使用将加载脚本的可执行文件的名称:

     perl script.pl
    
     python script.py
    

在这种情况下,shell 加载可执行文件perlpython并为其提供参数,可执行文件应该能够知道给定的参数是一个脚本并加载和执行它。

这里没有什么特别的魔力,shell 使用参数启动一个可执行文件。

  • 该脚本是可执行的并且自行启动:

    $ script.sh  
    $ ./script.pl  
    $ /some/path/script.py
    

通过调用将控制权交给内核execve。如果脚本是一个具有有效 she-bang(或例如 ELF 等可执行文件)的文本文件,内核将理解文件开头的神奇值并加载给定的解释器。解释器反过来将文本文件作为脚本加载并执行。

如果 shell 调用execve失败(例如,脚本没有有效的 she-bang),shell可能直接加载并执行脚本。这是由 bash 完成的。

并且,在某些情况下,来自man bash

如果程序是以#! 开头的文件,则第一行的其余部分指定该程序的解释器。 shell 在本身不处理此可执行格式的操作系统上执行指定的解释器。

如果您想了解更多详情请访问:

这 #! magic,有关各种 Unix 风格上的 shebang/hash-bang 机制的详细信息

很相似的问题

相关内容