python - 在Python中检查列表中的元素时循环

标签 python python-2.7 loops python-3.x interpreter

假设我有这样一段简单的代码:

for i in range(1000):
    if i in [150, 300, 500, 750]:
        print(i)

列表 [150, 300, 500, 750] 是否在循环的每次迭代中创建?或者我可以假设解释器(例如,CPython 2.7)足够聪明,可以优化它吗?

最佳答案

您可以使用 dis.dis 查看字节码.这是 CPython 2.7.11 的输出:

  2           0 SETUP_LOOP              40 (to 43)
              3 LOAD_GLOBAL              0 (range)
              6 LOAD_CONST               1 (1000)
              9 CALL_FUNCTION            1
             12 GET_ITER            
        >>   13 FOR_ITER                26 (to 42)
             16 STORE_FAST               0 (i)

  3          19 LOAD_FAST                0 (i)
             22 LOAD_CONST               6 ((150, 300, 500, 750))
             25 COMPARE_OP               6 (in)
             28 POP_JUMP_IF_FALSE       13

  4          31 LOAD_FAST                0 (i)
             34 PRINT_ITEM          
             35 PRINT_NEWLINE       
             36 JUMP_ABSOLUTE           13
             39 JUMP_ABSOLUTE           13
        >>   42 POP_BLOCK           
        >>   43 LOAD_CONST               0 (None)
             46 RETURN_VALUE      

因此,列表创建优化为加载常量元组(字节 22)。列表(在这种情况下实际上是一个元组)不会在每次迭代时重新创建。

关于python - 在Python中检查列表中的元素时循环,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35605836/

相关文章:

python - 提交表单后传递变量

python - [Pandas]如何获取每组top-n%的记录

python-2.7 - RASA 没有识别出正确的 Intent

string - 如何在Elixir中循环遍历字符串中的每个字符?

javascript - 在值上附加元素

javascript - 如何通过 jQuery 对象的属性值获取特定元素?

python - Pandas :根据条件更改单元格值

python - ValueError : need more than 1 value to unpack, 如何使我的代码更加健壮?

python - 如何正确复制嵌套的字典对象?

python - 在python中并行化数组行相似度计算