递归函数
如果一个函数在内部不调用其它的函数,而是自己本身的话,这个函数就递归函数。
递归函数形成条件
- 必须有一个明确的结束条件
- 每进行更深一层的递归时,问题规模相比上次递归都要有所减少
- 相邻两次重复之间有紧密的联系
代码演示
下图的代码逻辑:
- 第一次:4 + func(3)
- 第二次:4 + 3 + func(2)
- 第三次:4 + 3 + 2 + func(1)
- 在func(1)中,因为n==1,所以返回值1,代码结束,最终变成:4 + 3 + 2 + 1,结果为10

闭包
两个函数的嵌套, 内部函数使用到了外部函数的变量, 这个现象就可以称之为产生闭包。
构成条件
- 函数中嵌套了一个函数
- 内层函数使用了外层函数的变量
- 外层函数的返回值时内层函数的函数名

- 也可写成:outter()()

- 注意:虽然每次调用内函数,会开启一个函数,执行后消亡,但是闭包变量实际只有一份,每次使用内函数都在使用同一份闭包变量。

装饰器(语法糖用法、设置多个装饰器)
装饰器本质上是一个Python函数,它可以让其他函数在不需要做任何代码变动的前提下增加额外功能,装饰器的返回值也是一个函数对象。
装饰器:增加额外功能

语法糖的使用
语法糖用法:
@装饰器名称(放到需要装饰的函数的头上即可)

多个装饰器

本文深入探讨Python中的递归函数,解释其形成条件及代码示例。接着,介绍了闭包的概念,包括其构成条件和作用。最后,详细阐述了装饰器的使用,包括作为语法糖的功能增强和应用多个装饰器的方法,展示了如何在不修改原有代码的情况下为函数添加额外功能。
751

被折叠的 条评论
为什么被折叠?



