• 生成器的throw和close方法


    def gen_func():
        try:
            yield 1
        except Exception as e:
            pass
        yield 2
        yield 3
        yield 4
        yield 5
        return "bobby"
    
    if __name__ == "__main__":
        gen = gen_func()
        print(next(gen))
        a=gen.throw(Exception, "download error")
    print (a)#2
    print(next(gen))#注意,打印的是3不是2

    throw有两方面的作用,首先是抛给生成器一个异常,然后如果生成器能处理掉异常的话,throw方法接着迭代一次取得返回值,比如上面这个案例就抛给了生成器一个Exception异常,然后生成器处理掉了。注意,捕获异常是在上一次迭代中断的位置捕获,因为每次生成器运行的时候,都是从上一次发生yield中断的地方开始运行,所以抛来的异常发生在这个地方,捕获当然也要在这个地方。因为这个例子中异常被处理了,所以throw方法要完成他的第二张任务:让生成器迭代一次。于是,a为2

     再说close,他只有一个作用,就是像生成器抛出GeneratorExit异常。

    def myGenerator():  
        try:
            yield 1
            yield 2
        except GeneratorExit:
            print ("aa")
        #yield 如果加上这句话,则生成器抛出runtimeerror,close与前面文章GeneratorExit的最后一个例子中的del不同,这个runtimeerror主程序不会忽略,主程序因此异常而退出
     
    gen = myGenerator()
    print (next(gen))
    gen.close()
    print ('bb')
    
    '''
    aa
    bb
    '''

     关于xlose,可参考

    https://blog.csdn.net/hedan2013/article/details/72811117

    的论述:

    GeneratorExit异常的产生意味着生成器对象的生命周期已经结束。因此,一旦产生了GeneratorExit异常,生成器方法后续执行的语句中,不能再有yield语句,否则会产生RuntimeError。

  • 相关阅读:
    java中synchronized关键字分析
    如何查看java的class文件
    安装jdk1.9后报 Error:java: 无效的源发行版: 1.9
    mybatis拦截器获取sql
    NOIP2015 T4 推销员 贪心+堆优化
    BZOJ 2761: [JLOI2011]不重复数字 hash哈希
    Contest-hunter 暑假送温暖 SRM01
    Contest-hunter 暑假送温暖 SRM08
    洛谷P3393逃离僵尸岛 最短路
    bzoj 1433: [ZJOI2009]假期的宿舍 最大流
  • 原文地址:https://www.cnblogs.com/saolv/p/9853645.html
Copyright © 2020-2023  润新知