#!/usr/bin/env python3
# -*- coding: utf-8 -*-
def main():
for n in primes():
if n < 100:
print(n)
else:
break
def _odd_iter():
n = 1
while True:
n = n + 2
yield n
def _not_divisible(n):
return lambda x: x % n > 0
def primes():
yield 2
it = _odd_iter()
while True:
n = next(it)
yield n
it = filter(_not_divisible(n), it)
if __name__ == '__main__':
main()
如果将
it = filter(_not_divisible(n), it)
改成
it = filter(lambda x: x % n > 0, it)
两次结果不一样,是 n 的作用域问题? filter 惰性求值问题?