一般python脚本的第一行,都会有这么一个东西。以前写python,都不知道这个东西有什么用。。。所以最近研究了一下,发现还是有用处的。
写法
首先这个东西叫“shebang”。不知道为什么叫这个名字:)
这句话的正确写法是#! /usr/bin/python
。错误写法# !/usr/bin/python
。正确与错误的区别就在于#!之间是否有空格。没有空格就是正确的。有空格就是错误的。错误情况的示例如下:
语法错误
[root@jeremyqin1584598822574-0 /data]# ./a.py
./a.py: line 4: syntax error near unexpected token `('
./a.py: line 4: `def fun():'
作用
shebang其实是给Linux用的,不是给Python解释器(或者你说的“编译器”)用的,准确来说是给shell用的。它代表如果这个文件当作一个可执行文件来执行的时候,要调用哪个脚本引擎,像一般Shell脚本就会写#!/bin/bash之类。如果直接用python执行,是不需要的。对Python来说这就是一行注释。所以当这个Python脚本具备可执行权限时,利用./a.py
这种方式来执行时就生效了。系统通过解析shebang,来获取执行脚本所需要的执行引擎。
通常,有如下三种写法:
#! /usr/bin/python —>python2
#! /usr/bin/python3 —>python3
#! /usr/bin/env python ---->同时支持python2,python3
原理
这块内容是在知乎上看到的,记录下来
https://www.zhihu.com/question/68052314/answer/259441348
当你在 Unix 家族的命令行上执行 ./xxx.py 的时候,所使用的 shell 会先检查一下这个文件有没有可执行属性,有的话,fork 一个子进程,然后 exec 该文件。而在 exec 这个系统调用里,首先就得判断,要加载进来执行的文件倒底是啥格式呀,比如二进制可执行文件格式吧,Linux 默认就支持 a.out 和 elf 两种,所以加 exec 第一步就得把这个文件的头上一块读进内存了,search_binary_handler 来找一下对应的 bin_fmt_handler 内核模块,而处理可执行脚本的那个 binary format handler 叫 bin_fmt_script,它会解释 #! 后面的内容,最终用 bin_fmt_aout 或 bin_fmt_elf 将解释器装载进来执行,并将脚本路径做为参数传给解释器