摘要: 当我们需要处理一个大量的数据集合时,一次性将其全部读入内存并处理可能会导致内存溢出。此时,我们可以采用迭代器`Iterator`和生成器`Generator`的方法,逐个地处理数据,从而避免内存溢出的问题。迭代器是一个可以逐个访问元素的对象,它实现了`python`的迭代协议,即实现了`__iter__()`和`__next__()`方法。通过调用`__next__()`方法,我们可以逐个访问迭代器中的元素,直到所有元素都被访问完毕,此时再次调用`__next__()`方法会引发`StopIteration`异常。生成器是一种特殊的迭代器,它的实现方式更为简洁,即通过`yield`语句来实现。生成器函数使用`yield`语句返回值,当生成器函数被调用时,它会返回一个生成器对象,通过调用`__next__()`方法来逐个访问生成器中的元素,直到所有元素都被访问完毕,此时再次调用`__next__()`方法会引发`StopIteration`异常。 阅读全文
posted @ 2023-08-12 12:15 lyshark 阅读(798) 评论(0) 推荐(1) 编辑

loading... | loading...
博客园 - 开发者的网上家园