zoukankan      html  css  js  c++  java
  • for循环的本质

    for循环的本质

    • 是在对一个迭代器进行操作。首先for循环在遍历可迭代对象的时候会把可迭代对象通过函数iter()或__iter__方法返回一个迭代器,然后在对这个迭代器对象进行操作。迭代器可以用next()或__next__方法得到返回值,当把所有的值取完时会抛出StopIteration错误,这个错误在for循环中python会自己处理,不会展示给开发者。

    • 转:在python中,使用iter函数可以获得有序聚合类型的迭代器,我个人将迭代器理解为带有next指针的单向链表,获取到的迭代器为链表的表头,表头内容为空,next指针指向有序聚合类型的第一个元素。在访问链表最后一个元素的next指针时,python会报错StopIteration。 --------------------- 本文来自 jimmy_gyn 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/jimmy_gyn/article/details/79143682?utm_source=copy

    • 如:

    >>> a = [1,2,3,4]
    >>> b = iter(a)
    >>> b
    <list_iterator object at 0x0000016A7CF3A828>
    >>> next(b)
    1
    >>> next(b)
    2
    >>> next(b)
    3
    >>> next(b)
    4
    >>> next(b)
    Traceback (most recent call last):
      File "<stdin>", line 1, in <module>
    StopIteration
    >>> for var in a:
    ...     print(var)
    ...
    1
    2
    3
    4
    • 反编译for循环可以发现GET_ITER相当于iter()返回一个迭代器,FOR_ITER相当于next()遍历并取出每一个值。

      >>> import dis
      >>> x = [1,2,3]
      >>> dis.dis('for i in x: pass')
        1           0 SETUP_LOOP              12 (to 14)
                    2 LOAD_NAME                0 (x)
                    4 GET_ITER
              >>    6 FOR_ITER                 4 (to 12)
                    8 STORE_NAME               1 (i)
                   10 JUMP_ABSOLUTE            6
              >>   12 POP_BLOCK
              >>   14 LOAD_CONST               0 (None)
                   16 RETURN_VALUE
    • 所以在for循环中对数据操作的的时候,就会出现各种异常。

    • 比如for循环遍历删除,不会把一个列表删除干净。

    >>> for var in a:
    ...     a.remove(var)
    >>> a
    [2, 4]
    • 可以使用浅拷贝的方法删除。

    >>> c = a.copy()
    >>> for var in c:
    ...     a.remove(var)
    >>> a
    []

     

  • 相关阅读:
    LOJ #6183 看无可看
    BZOJ 5467 Slay the Spire
    BZOJ 5306 [HAOI2018] 染色
    BZOJ 2784 时间流逝
    BZOJ4911: [Sdoi2017]切树游戏
    min-max 容斥
    BZOJ 5475: [WC 2019] 数树
    BZOJ 2810 [Apio2012]kunai
    Codeforces round 1083
    详解大数据数据仓库分层架构
  • 原文地址:https://www.cnblogs.com/kmnskd/p/9905297.html
Copyright © 2011-2022 走看看