迭代器、生成器,sort和sorted函数区别,continue和break区别

本文深入解析迭代器和生成器的概念与特性,对比两者差异,探讨它们在处理大型数据集时的优势,同时讲解sort与sorted、continue与break的区别。

迭代器

定义

  • 是访问集合元素的一种方式。
  • 迭代器对象从集合的第一个元素开始访问,直到所有的元素被访问完结束。
  • 迭代器只能往前不会后退,另外,迭代器的一大优点是不要求事先准备好整个迭代过程中所有的元素。迭代器仅仅在迭代到某个元素时才计算该元素,而在这之前或之后,元素可以不存在或者被销毁。这个特点使得它特别适合用于遍历一些巨大的或是无限的集合,比如几个G的文件。
  • 迭代器是一个对象,不是一个函数

特点

  1. 访问者不需要关心迭代器内部的结构,仅需通过next()方法或不断去取下一个内容;
  2. 不能随机访问集合中的某个值 ,只能从头到尾依次访问;
  3. 访问到一半时不能往回退;
  4. 便于循环比较大的数据集合,节省内存;
  5. 也不能复制一个迭代器。如果要再次(或者同时)迭代同一个对象,只能去创建另一个迭代器对象。enumerate()的返回值就是一个迭代器;
  6. 迭代器提供了一种不依赖于索引的取值方式,这样就可以遍历那些没有索引的可迭代对象了(字典,集合,文件),一个迭代器只能取所有数据一次;
  7. 迭代器与列表比较,迭代器是惰性计算的,更节省内存。

生成器

定义

  • 生成器是一种特殊的迭代器。不过这种迭代器更加优雅。它不需要再像上面的类一样写__iter__()和__next__()方法了,只需要一个yiled关键字;、

  • 生成器一定是迭代器(反之不成立),因此任何生成器也是以一种懒加载的模式生成值。 语法上说,生成器函数是一个带yield关键字的函数;

  • 调用生成器函数后会得到一个生成器对象,这个生成器对象实际上就是一个特殊的迭代器,拥有__iter__()和__next__()方法。

特点

  1. 生成器函数:yield语句一次返回一个结果,在每个结果中间,挂起函数的状态,以便下次重它离开的地方继续执行;

  2. 生成器表达式:类似于列表推导,但是,生成器返回按需产生结果的一个对象,而不是一次构建一个结果列表。

sort和sorted函数区别

  • sorted()属于内置函数,作用于任意可迭代的对象,sorted() 函数总是会返回一个排序后的列表,原有列表保持不变

  • sort()一般作用于列表,属于列表的成员函数,它会直接修改原有列表,函数返回为 None。sort()函数总体来说不需要复制原有列表,所以消耗内存比较小,效率也比较高

continue和break区别

  • 只能在循环体内和switch语句体内使用break语句,
  • 当break出现在循环体中的switch语句体时,其作用是跳出该switch语句体。
  • 当break出现在循环体中,但不在switch语句体中时,则在执行 break后,跳出本层循环体。
  • continue语句的作用是,跳过本次循环体中余下尚未执行的语句,接着再一次进行循环的条件判定。
  • 在循环体内使用break语句可以使流程跳出本层循环体,从而提前结束本层循环
  • 在while和do…while循环中,continue语句并没有使整个循环终止
  • continue的作用是结束本次循环,即跳过本次循环体中余下尚未执行的语句,接着再一次进行循环判断
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

YouShouldKnowMe

别来这套

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值