V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
saximi
V2EX  ›  Python

请教一个关于生成器表达式的问题

  •  
  •   saximi · 2017-07-31 20:36:17 +08:00 · 1899 次点击
    这是一个创建于 2664 天前的主题,其中的信息可能已经有所发展或是发生改变。
    iters = list(map(iter, ('ab','12')))
    while iters:
    try:
    res = [next(i) for i in iters] #语句 1
    print("res=",res)
    except StopIteration:
    print("OVER")
    break

    上面这段程序输出如下:
    res= ['a', '1']
    res= ['b', '2']
    OVER

    但是把语句 1 中方括号变成圆括号后,语句 1 变成:“ res = (next(i) for i in iters)”,此时输出是如下两条信息的反复循环:
    res= at 0x020881E0>
    res= at 0x02088480>
    ...

    我的问题是:
    为何语句 1 中方括号变成圆括号,res 此时变成了生成器表达式后,会导致输出无限循环?

    请大家指点,感谢!
    4 条回复    2017-07-31 22:59:18 +08:00
    glasslion
        1
    glasslion  
       2017-07-31 22:01:55 +08:00
    生成器表达式是惰性的,你不去遍历它, next(i) 就不会被实际执行, 就不会触发 StopIteration, 结束循环
    Pysensor
        2
    Pysensor  
       2017-07-31 22:04:16 +08:00
    拙见。。。其实不管你的 res 是不是改成生成器表达式,你给 res 赋任意一个值,都会是无限循环的,这就差不多是 while True: print(res)
    wisej
        3
    wisej  
       2017-07-31 22:08:09 +08:00
    res = [next(i) for i in iters] 会执行 next(i).
    然而,当你将方括号变成圆括号后,python 解释器执行到语句 1 的时候,只会生成一个 generator object (里面包含了生成器表达式所在行等信息) ,同时 res 指向它。但是,这个 generator 并不会被执行,也就意味着无论是 iter 还是 i 都不会触发 StopIteration.最后的结果就是无限循环了
    saximi
        4
    saximi  
    OP
       2017-07-31 22:59:18 +08:00
    感谢大家指点!
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2548 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 15:45 · PVG 23:45 · LAX 07:45 · JFK 10:45
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.