测试题(笔试,不能上机哦~):
0. 通常,一般的函数从第一行代码开始执行,并在什么情况下结束?
答:执行到最后一句、碰到return或者yield
1. 什么是协同程序?
答:可以运行的独立函数调用,可以中断、暂停、挂起、继续。
2. 生成器所能实现的任何操作都可以由迭代器来代替吗,为什么?
答:可以,生成器的本质是一个特殊的迭代器。
3. 将一个函数改造为生成器,说白了就是把什么语句改为 yield 语句?
答:return 改成 yield
4. 说到底,生成器的最大作用是什么?
答:让代码变得更加简洁
5. 如下,get_prime() 是一个获得素数的生成器,请问第 2 行代码 while True 有何作用?
- def get_primes(number):
- while True:
- if is_prime(number):
- yield number
- number += 1
答:保证数据的连续
动动手(一定要自己动手试试哦~):0. 要求实现一个功能与 reversed() 相同(内置函数 reversed(seq) 是返回一个迭代器,是序列 seq 的逆序显示)的生成器。例如:
- >>> for i in myRev("FishC"):
- print(i, end='')
- ChsiF
1. 10 以内的素数之和是:2 + 3 + 5 + 7 = 17,那么请编写程序,计算 2000000 以内的素数之和?
本讲总结:
1.生成器的最大作用:使得函数可以保留现场
2.素数有好几种判断方法