python代码是如何执行的?
解释运行程序
回忆上次内容
py文件的程序是按照顺序- 一行行挨排解释执行的
- 我们可以
python3 -m pdb hello.py来对程序调试 - 调试的目的是去除
bug - 别害怕
bug bug会有提示- 我们也就知道如何
debug调试
顺序执行
- 程序在文本中从上到下是一行行写的
- 调试的时候也是从头到尾一行行执行的
- 但是执行的时候是如何把代码一行行解释执行的呢?
说到底
python3到底是个啥呢?python3又是怎么解释hello.py的?- 这两这节课相当复杂
- 如果感觉太过复杂
- 可以直接跳过
- 不影响后面的理解
- 我们先要看看python3对Guido.py做了些什么???
tokenize
- 首先把字符分组成词
- 词法分析(lexical analysis)中
编辑
- 把原来的字符流
变成了词的流
- token(令牌)流
编辑
- 词法分析之后输出的是一个token流
什么是token流呢?
- 首先要知道什么是token
token
token
- 令牌
编辑
古人说听我号令
- 号指的是号角
令指的是令牌
- 急急如律令
- 令行禁止
- 怎么把源文件变成一个token流呢?
python3模块
- 这个东西是python3的一个模块
正在上传…重新上传取消
- 具体怎么运行呢?
token流
我们尝试运行
- python3 -m tokenize guido.py
- 对guido.py进行词法分析
- 分析出来的词(token)流长什么样子呢?
编辑
- 这个词怎么理解呢?
token流
- 第0行设置了编码格式
第1行[0,5)字符是第1行第1个token
- print是一个Name(名字)
第1行[5,6)字符是第1行第2个token
- (
- (是一个Operator(操作符)
第1行[6,30)字符是第1行第3个token
- "1982------Guido in cwi"
- 这是一个String(字符串)
第1行[30,31)字符是第1行第4个token
- )
- )是一个Operator(操作符)
第1行[31,32)字符是第1行第5个token
- \n
- \n是一个NewLine(换行符)
- 换行符意味着第一行结束
- 第2行...
编辑
- 词分析出来之后呢?
组词
词分析出来就是怎么组词的问题
- 哪些词和哪些词先组合
- 哪些词和哪些词后组合
生成一棵抽象语法树
- AST(Abstract Syntax Tree)
编辑
- 具体怎么生成这棵ast树呢?
引入ast模块
编辑
- 具体怎么做呢?
流程
- 先把这个ast模块导入(import)进来
- 然后读取guido.py并送到s
- 然后对于s进行语法分析(parse)
编辑
- 不过这乱七八糟堆一起怎么理解呢?
缩进换行
- 把分析的结果进行dump(转储)
编辑
- 目前lanqiao.cn上面的python是3.8
- 这个换行需要在3.9以上完成
- 只能在本地演示一下
缩进演示
编辑
- 这个就是把词组成语法树的样子
- 但是语法树还不能直接执行
- 什么才能直接执行呢?
翻译成字节码
- 字节码(指令)才能真正执行
- 怎么把ast转化为字节码(指令)呢?
- 需要编译
从一种语言到另一种语言
- 从py文件
- 到字节码(指令)
编辑
- 我可以看看这个编译过程么?
compile
编辑
编辑
- 这个东西完全是乱码
- 我看不懂啊?
- vi打开这个这个pyc文件
二进制形态
- :set wrap设置换行
编辑
- 可以看到他的二进制形态么?
二进制
:%!xxd
- 把文件转化为二进制
编辑
- 实在是看不懂啊
- 能把这个字节码(指令)变成我们人能看懂的么?
反编译
disassembler这个词由两部分组成
- dis (反着来的)
- assembler (汇编语言)
整体就是
- 把py源文件编译成的字节码(指令)
- 反编译(disassembler)成这些字节码对应的助记符(指令的含义)
编辑
- 这可以用么?
- 去试试!
反编译(dis)
- python3 -m dis guido.py
编辑
我们可以看见
- 前面是行号
每行对应4条指令
- LOAD_NAME 装载函数名
- LOAD_CONST 装载参数
- CALL_FUNCTION 调用函数
- POP_TOP 弹栈返回
- 每条指令对应一个字节码
- 那具体这个LOAD_NAME是什么意思呢?
指令
- 指令对应着一个字节码状态
编辑
- 但是LOAD_NAME这条指令
- 具体对应什么二进制字节状态呢?
二进制状态
编辑
- 我们找找程序中的4条指令对应的字节状态
4条指令
| 指令助记符 | 指令含义 | 十进制状态 | 十六进制状态 |
|---|---|---|---|
| LOAD_NAME | 装载函数名称 | 101 | 0x65 |
| LOAD_CONST | 装载参数 | 100 | 0x64 |
| CALL_FUNCTION | 调用函数 | 142 | 0x8e |
| POP_TOP | 弹栈返回 | 1 | 0x01 |
- 可以找到源代码的对应关系么?
编辑
- 好像找到了
- 但是0x83 对应的是 GET_AWAITABLE
- 显然00 83是从表中的0号位置取得字符串变量
- 01 83是从表中的1号位置取字符串
- 以此类推,直到05 83
那这些代码究竟是什么指令集的呢?
- 龙芯
- intel
- 还是arm呢?
虚拟机的虚拟cpu
- 这些字节码(bytecode)对应的是python虚拟机上面虚拟cpu的指令集
编辑
- 怎么还有虚拟机
- 虚拟cpu呢?
- 我们先把这节课总结一下
总结
我们把python源文件
- 词法分析 得到 词流(token stream)
- 语法分析 得到 抽象语法树(Abstract Syntax Tree)
- 编译 得到 字节码 (bytecode)
- 反编译 得到 指令文件
编辑
- 不过这个指令文件是基于虚拟机的虚拟cpu的指令集
- 怎么这么虚呢?
- 我们下次再说
本文章来自于《oeasy教您玩转python》(https://www.lanqiao.cn/courses/3584)中第6个实验。
python代码是如何执行的?的更多相关文章
- JAVA,Python代码是编译执行还是解释执行?
转载地址:http://blog.csdn.net/zv3e189os5c0tsknrbcl/article/details/78661641 有人在讨论 Python 代码是编译执行还是解释执行?这 ...
- 关于python代码是编译执行还是解释执行
Python 是编译型语言还是解释型语言?回答这个问题前,应该先弄清楚什么是编译型语言,什么是解释型语言. 所谓编译执行就是源代码经过编译器编译处理,生成目标机器码,就是机器能直接运行的二进制代码,下 ...
- 交互模式下测试python代码及变量的四则运算
在交互模式下,python代码可以立即执行,所以这很方便我们进行代码测试 1.命令窗口,输入python (如果没配置环境变量则需带python安装目录的绝对路径) >>> 这个就是 ...
- 深入理解 GIL:如何写出高性能及线程安全的 Python 代码
深入理解 GIL:如何写出高性能及线程安全的 Python 代码 本文由 伯乐在线 - 郑芸 翻译.未经许可,禁止转载!英文出处:A. Jesse.欢迎加入翻译组. GIL对多线程的影响:http:/ ...
- python代码块,小数据池,驻留机制深入剖析
一,什么是代码块. 根据官网提示我们可以获知: 根据提示我们从官方文档找到了这样的说法: A Python program is constructed from code blocks. A blo ...
- 一种部署 Python 代码的新方法
在Nylas,我们喜欢使用Python进行开发.它的语法简单并富有表现力,拥有大量可用的开源模块和框架,而且这个社区既受欢迎又有多样性.我们的后台是纯用 Python 写的,团队也经常在 PyCon ...
- 用Pylint规范化Python代码,附PyCharm配置
Pylint一个可以检查Python代码错误,执行代码规范的工具.它还可以对代码风格提出建议. 官网:https://pylint.readthedocs.io pip install pylint ...
- Python代码的编译
Python代码的编译 Python代码在解释执行之前,是会被编译成.pyc或者.pyo文件的,它们是中间字节码表示的文件,之后Python虚拟机才会去解释执行它们. 1.pyc文件 ======== ...
- Python基础:27执行环境
一:可调用对象 可调用对象,是任何能通过函数操作符“()”来调用的对象.Python 有4 种可调用对象:函数,方法,类,以及一些类的实例. 1:函数 python 有 3 种不同类型的函数对象. a ...
随机推荐
- axios源码解析 - 请求拦截器
axios请求拦截器,也就是在请求发送之前执行自定义的函数. axios源码版本 - ^0.27.2 (源码是精简版) 平时在业务中会这样去写请求拦截器,代码如下: // 创建一个新的实例 var s ...
- 在Vmware虚拟机(win10)中安装逍遥安卓模拟器遇到的问题及解决办法
0x00 下载正确的安装包 逍遥模拟器官网:逍遥安卓模拟器下载官网 (xyaz.cn) 为什么要强调下载正确的安装包? 因为我在第一次下载的时候就下错了,下的是 逍遥模拟器 - 电脑玩手游神器 (me ...
- 安装Net-Tools到CentOS(YUM)
Net-Tools是一个Linux系统中基本的网络工具集,其集成了常用的网络管理命令"ifconfig.netstat.arp.route等". 运行环境 系统版本:CentOS ...
- 如何优化PlantUML流程图(时序图)
这篇文章用来介绍,如何画出好看的流程图. 1. 选择合适的组件 1.1 plantuml官方提供的组件 1.2 加载图片 1.2.1 加载本地图片 1.2.2 加载网络图片 1.2.3 图片资源 2. ...
- 商户编号[Merchant Id]是什么
1. Merchant Id是什么 2. Merchant Id 是有哪几个部分构成的 2.1 收单机构代码 2.2 商户地区代码 2.3 Merchant Category Code(MCC) 本文 ...
- vue虚拟dom和diff算法
vue的虚拟dom和diff算法 1.虚拟dom 虚拟dom,我的理解就是通过js对象的方式来具体化每一个节点,把dom树上面的每个节点都变为对象里的一个元素,元素的子元素变为子节点,节点上面的cla ...
- CVE-2022-30190 Follina Office RCE分析【附自定义word钓鱼模板POC】
昨天看了下'Follina' MS-MSDT n-day Microsoft Office RCE 这个漏洞,修改了下chvancooten的脚本,实现可以自定义word模板,便于实战中钓鱼使用,自己 ...
- 拒绝蛮力,高效查看Linux日志文件!
原创:扣钉日记(微信公众号ID:codelogs),欢迎分享,转载请保留出处. 简介 日常分析问题时,会频繁地查看分析日志,但如果蛮力去查看日志,耗时费力还不一定有效果,因此我总结了在Linux常用的 ...
- Python量化-如何获取实时股票信息
如何获取实时股票信息 股票信息的接口有很多,之前大家常用的是新浪的,但在年初的时候,新浪的接口突然不能使用,给大家造成了很大的困扰,为此网上也有很多教程教大家如何从新浪获取数据,跟着教程弄了半天也不行 ...
- DAST 黑盒漏洞扫描器 第五篇:漏洞扫描引擎与服务能力
0X01 前言 转载请标明来源:https://www.cnblogs.com/huim/ 本身需要对外有良好的服务能力,对内流程透明,有日志.问题排查简便. 这里的服务能力指的是系统层面的服务,将扫 ...