递归函数
如果一个函数在内部不调用其它的函数,而是自己本身的话,这个函数就递归函数。
递归函数形成条件
- 必须有一个明确的结束条件
- 每进行更深一层的递归时,问题规模相比上次递归都要有所减少
- 相邻两次重复之间有紧密的联系
代码演示
下图的代码逻辑:
- 第一次:4 + func(3)
- 第二次:4 + 3 + func(2)
- 第三次:4 + 3 + 2 + func(1)
- 在func(1)中,因为n==1,所以返回值1,代码结束,最终变成:4 + 3 + 2 + 1,结果为10
闭包
两个函数的嵌套, 内部函数使用到了外部函数的变量, 这个现象就可以称之为产生闭包。
构成条件
- 函数中嵌套了一个函数
- 内层函数使用了外层函数的变量
- 外层函数的返回值时内层函数的函数名
也可写成:outter()()
注意:虽然每次调用内函数,会开启一个函数,执行后消亡,但是闭包变量实际只有一份,每次使用内函数都在使用同一份闭包变量。
装饰器(语法糖用法、设置多个装饰器)
装饰器本质上是一个Python函数,它可以让其他函数在不需要做任何代码变动的前提下增加额外功能,装饰器的返回值也是一个函数对象。
装饰器:增加额外功能
语法糖的使用
语法糖用法:
@装饰器名称(放到需要装饰的函数的头上即可)
多个装饰器