一日一技:生成器里面的 return 有什么用?

简介: 一日一技:生成器里面的 return 有什么用?

有一位同学问了这样一个问题:


def gen_data(num):
    if num > 10:
        for i in range(num):
            yield i
    else:
        return num
generator = gen_data(5)
for num in generator:
    print(num)


当传入的的参数小于等于10 的时候,为什么没有返回这个参数本身?


这道题,当我们传入的参数大于10的时候,能得到符合预期的结果,如下图所示:


1.png


但是,当我们传入数据5的时候,我们来看看运行效果:


2.png


可以看到,数字5并没有被打印出来,程序直接运行到了最后。


之所以会出现这种情况,是因为这个同学以为,当参数大于10的时候,gen_data(12)返回的是生成器,而当参数不大于10的时候,返回的是一个数字。显然这样的想法是不对的,否则,for num in 10这种语法早就报错了,数字是不能被迭代的。


正确的说法应该是,因为gen_data里面有yield,所以gen_data(参数)返回一个生成器。无论参数传入的是什么,返回的都是生成器。如下图所示:


3.png


为了说明为什么传入参数为5的时候,for 循环不执行,我们简化一下代码:


def gen_data():
    yield 1
    yield 2
    yield 3
    return 4
generator = gen_data()
for num in generator:
    print(num)


运行效果如下图所示:


4.png


可以看到,对于这样一个非常简单的生成器,在 for 循环里面也只是打印了数字123,并没有打印数字4。


关于生成器中的return,我们可以从 Python 官方文档PEP 255 — Simple


Generators[1]中找到说明:


5.png


return 在生成器中,表示生成器运行完成了,可以结束了。然后生成器会抛出一个StopIteration的异常。而for循环能够检测到这个异常,于是结束循环。所以当我们传入的参数为5的时候,生成器直接运行到了 return,于是它直接就抛出StopIteration,于是 for 循环检测到这个异常就结束了。


在生成器里面的return只是一个结束标志,它不会把后面写的值返回给调用者。这跟函数里面的return语句是不一样的。


请关注微信公众号【未闻Code】获取更多精彩文章。

目录
相关文章
|
8月前
|
C#
C#学习相关系列之yield和return的区别
C#学习相关系列之yield和return的区别
157 1
|
5月前
|
Python
`return` 和 `yield` 关键字之间的区别
【8月更文挑战第29天】
57 5
|
5月前
dict 和 set 的 8 个经典使用例子
dict 和 set 的 8 个经典使用例子
57 4
|
6月前
|
语音技术 Python
语音识别,continue和break的使用,循环综合案例,完成发工资案例,函数的初体验,len()是内置好的函数,def 函数名 def xxx(),函数的定义 def xxx() ,调用函数
语音识别,continue和break的使用,循环综合案例,完成发工资案例,函数的初体验,len()是内置好的函数,def 函数名 def xxx(),函数的定义 def xxx() ,调用函数
|
算法 Python
python--迭代器、isinstance、生成器、send
python--迭代器、isinstance、生成器、send
生成器函数, re中函数的使用,模拟range的功能
1、生成1-10使用next(generator)方法获取1-10 2、使用for循环获取
67 0
return的作用
js中的函数只是实现某种功能,最终的结果需要返回给函数的调用者 函数名( ) 通过return实现的。 只要函数遇到return 就把后面的结果,返回给函数的调用者。 函数名 ( ) = return 后面的结果。
|
前端开发
前端学习案例1-empty和undefined区别
前端学习案例1-empty和undefined区别
93 0
前端学习案例1-empty和undefined区别
|
JSON JavaScript 数据格式
res 对象的常见方法|学习笔记
快速学习 res 对象的常见方法
res 对象的常见方法|学习笔记
|
JavaScript 数据安全/隐私保护 前端开发
js中return,return true,return false三者的用法及区别
return其实就是return undefined; 1.语法及返回方式 ①返回控制与函数结果         语法为:return 表达式;         语句结果函数的执行,返回调用函数,而且把表达式的值作为函数结果返回出去 ②返回控制无函数结果         语法为:return;         在大多数情况下,为事件处理函数如果让其返回false,可以防止默认的事件行为.
1663 0