使用生成器表达式而不是列表进行sorted()

使用生成器表达式而不是列表进行sorted(),第1张

使用生成器表达式而不是列表进行sorted()

首先要做的

sorted()
是将数据转换为列表。基本上,实现的第一行(在参数验证之后)是

newlist = PySequence_List(seq);

另请参见完整的源代码版本2.7和版本3.1.2。

编辑 :正如aaronasterling在答案中指出的那样,变量

newlist
是一个
列表。如果参数已经是列表,则将其复制。因此,生成器表达式确实具有使用较少内存的优势。

有很大的好处。由于sorted不会影响按顺序传递,因此必须对其进行复制。如果它是根据生成器表达式创建列表,则仅生成一个列表。如果传入了列表理解,则首先建立列表,然后对其sorted进行复制以进行排序。

这反映在行中

newlist = PySequence_List(seq);

在Sven Marnach的回答中引用。本质上,这将无条件地复制传递给它的任何序列的副本。



欢迎分享,转载请注明来源:内存溢出

原文地址:https://www.54852.com/zaji/5646715.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-12-16
下一篇2022-12-16

发表评论

登录后才能评论

评论列表(0条)

    保存