相关疑难解决方法(0)

为什么在编译为字节码时没有优化整数除法?

首先,让我展示一下我做的实验:

In [69]: dis.dis(lambda : 4 / 2 +  1.5 * 2 + (4 - 2))
  1           0 LOAD_CONST               1 (4)
              3 LOAD_CONST               2 (2)
              6 BINARY_DIVIDE       
              7 LOAD_CONST               4 (3.0)
             10 BINARY_ADD          
             11 LOAD_CONST               5 (2)
             14 BINARY_ADD          
             15 RETURN_VALUE 
Run Code Online (Sandbox Code Playgroud)

正如您在输出中看到的那样dis.dis,1.5 * 2并且4 - 2编译为LOAD_CONST而不是两个LOAD_CONST后跟二进制操作.

4 / 2不会被类似的东西所取代LOAD_CONST 4 (2).

我想知道为什么在优化中遗漏了分裂.

我使用的Python版本是2.7.5.

顺便说一句,似乎在Python 3中,这样的函数得到了更好的优化,这就是我所看到的:

>>> dis.dis(lambda : 4 / 2 +  1.5 * 2 + …
Run Code Online (Sandbox Code Playgroud)

python bytecode python-internals

4
推荐指数
1
解决办法
98
查看次数

标签 统计

bytecode ×1

python ×1

python-internals ×1