python3之闭包的概念(轻松理解)

   日期:2020-07-18     浏览:100    评论:0    
核心提示:目录定义闭包结构示例闭包应用案例一(计数器)闭包应用案例二(求和)案例总结(闭包里数据的特征)定义python中满足以下3条的我们称它为闭包:1.函数里定义了内部函数2.外部函数有返回值且返回的值是内存部函数名3.内部函数调用了外部函数的变量。闭包结构示例def fun(): c = 0 def fun_chicer(): #函数里定义了内部函数 c = c + 1 #内部函数调用了外部函数的变量。 print(有帮助就点个赞, c)

目录

    • 定义
    • 闭包结构示例
    • 闭包应用案例一(计数器)
    • 闭包应用案例二(求和)
    • 案例总结(闭包里数据的特征)

定义

python中满足以下3条的我们称它为闭包:

1.函数里定义了内部函数
2.外部函数有返回值且返回的值是内存部函数名
3.内部函数调用了外部函数的变量。

闭包结构示例

def fun():
    c = 0

    def fun_chicer(): #函数里定义了内部函数
        c = c + 1 #内部函数调用了外部函数的变量。
        print("有帮助就点个赞", c)
    return fun_chicer #外部函数有返回值且返回的值是内存部函数名

总结:
      到这一步就已经理解了闭包的基本结构了。

闭包应用案例一(计数器)

def number_group():
    numbers = [0]

    def add_one():
        numbers[0] += 1
        print(f'第{numbers[0]}次调用')
    return add_one


x = number_group() 
x()
x()
x()
运行结果:1次调用
第2次调用
第3次调用

分析:
      可以看到内部函数add_one被重复调用3次,直到程序运行结束才释放内存空间。

闭包应用案例二(求和)

def fun(a, b):
    c = 100

    def fun_chicer():
        s = a + b + c
        print("相加后的和为:", s)
    return fun_chicer


x = fun(1, 2)
b = fun(2, 4)
x()
b()
运行结果:
相加后的和为: 103
相加后的和为: 106

分析:
      我们发现总共传入参数2次,重新传入参数后,上一次传入的数据仍然被保留。且不会受第二次传入数据的影响。

案例总结(闭包里数据的特征)

      1.在闭包中,内部函数调用一次后所划分的内存空间是程序结束后才会释放
      2.闭包中,重传参数后不会释放上次调用的内存空间,而是重新划分新的空间保存这次的数据,且函数能重复调用
      3.在调用时可以对其中的数据进行修改(不止我所列的一种)

宝剑锋从磨砺出 梅花香自苦寒来
 
打赏
 本文转载自:网络 
所有权利归属于原作者,如文章来源标示错误或侵犯了您的权利请联系微信13520258486
更多>最近资讯中心
更多>最新资讯中心
0相关评论

推荐图文
推荐资讯中心
点击排行
最新信息
新手指南
采购商服务
供应商服务
交易安全
关注我们
手机网站:
新浪微博:
微信关注:

13520258486

周一至周五 9:00-18:00
(其他时间联系在线客服)

24小时在线客服