闭包内容:

  1. 匿名函数:能够完成简单的功能,传递这个函数的引用,只有功能

  2. 普通函数:能够完成复杂的功能,传递这个函数的引用,只有功能

  3. 闭包:能够完成较为复杂的功能,传递这个闭包中的函数以及数据,因此传递是功能+数据

  4. 对象:能够完成最复杂的功能,传递很多数据+很多功能,因此传递的是数据+功能

———————————————————

  1. 对全局函数进行修改:在函数当中加global,在闭包中外边中的变量加nonlocal

  2. 闭包定义:有两个函数嵌套使用,里面的函数可以使用外面函数所传输的参数,最后可传递的是里面函数的结构与数据(个人理解)。

  3. 最后闭包可以在python中引申出装饰器 ———————————————————

 def closure():
# 在函数内部再定义一个函数,
# 并且这个函数用到了外边函数的变量,那么将这个函数以及用到的一些变量称之为闭包
def closure_in(x):
print('---------我是打不死的%s--------' %x)
return closure_in

x = closure()
x('小强')

print('*'*20)
# -----加餐---------
def closure_1(a,b,c):
def closure_on(x):
print('-----%s加餐-------' %b)
print(a*x + c)
return closure_on

demo = closure_1(2,'小强',3) #传closure_1函数
demo(4) #传clsure_on函数

#注:函数不加括号,调用的是函数本身【function】;函数加括号,调用的是函数的return结果。

装饰器内容:

代码要遵守‘开放封闭’原则;对已经写好的函数遵守封闭,对功能扩展遵守开放;

 # 装饰器的作用:为了对原来的代码上进行扩展
def decoration(func):
def call_func():
print('-------正在装饰 -------' )
func()
return call_func

#@decoration #--->demo_new = decoration(demo)
def demo():
print('demo----')

demo_new = decoration(demo)
demo_new()

使用装饰器来测试一个函数的运行时:

 import time
def set_func(func):
def call_func():
start_time = time.time()
func()
stop_func = time.time()
print(‘alltimes is %f’ %(stop_func-start_fun))
return call_func
@set_func
def test1():
print(‘——-test1———’)
test1()

#等价于:
@set_func==test1 = set_func(test1)
1. 没有参数,没有返回值的函数进行装饰:
 def set_func(func):
def call_func():
print(‘———test2——-’)
print(‘———-test3——’)
func()
return call_func @set_func
def test1():
print(‘——test1——- ’)
2. 对有参数无返回值的函数进行装饰:
 def set_func(func):
def call_func(a): #变
print(‘———test2——-’)
print(‘———-test3——’)
func(a) #变
return call_func @set_func
def test1(num):
print(‘——test1——- %d ’ %num)

test1(100) —->call_func(100)
test1(200)——>call_func(200)

复现装饰器原理:

————————————————————————-

只要遇到@函数 装饰器(这句话),在程序中就已经执行了!!
3. 不定长参数的函数装饰:
 def set_func(func):
def call_func(*args,**kwargs): #变
print(‘———test2——-’)
print(‘———-test3——’)
func(*args,**kwargs) #(拆包)将元祖拆开,每个进行传输;
#func(args,kwargs)—>不行,相当于传递了两个参数:一个元祖,一个字典。
return call_func @set_func
def test1(num,*args,**kwargs):
print(‘——test1——- %d ’ %num)
print(‘——test1——- ’ , args)
print(‘——test1——- ’ ,kwargs ) test1(100)
test1(100,200)
test1(100,200,300,mm=100)

注意:*args保存不定长参数,以元祖保存,**kwargs保存字典形式(mm=...)

4.对应的返回值参数进行装饰、通用装饰器:
 #通用装饰器
def set_func(func):
print(“开始进行装饰———-”)
def call_func(*args,**kwargs): #变
print(‘———test2——-’)
print(‘———-test3——’)
return func(*args,**kwargs) #(拆包)将元祖拆开,每个进行传输;如果没有return ret返回none。
#func(args,kwargs)—>不行,相当于传递了两个参数:一个元祖,一个字典。
return call_func @set_func
def test1(num,*args,**kwargs):
print(‘——test1——- %d ’ %num)
print(‘——test1——- ’ , args)
print(‘——test1——- ’ ,kwargs )
return ‘ok’ #—-返回给上面的func(),然后return func—ret ret = test1(100)
5. 多个装饰器对同一个函数进行装饰:
 def add_qx(func):
print(“——开始进行装饰权限1———-”)
def call_func(*args,**kwargs): #变
print(‘这是权限验证1’)
return func(*args,**kwargs)
return call_func ​
def add_xx(func):
print(“——开始进行装饰xx功能———-”)
def call_func(*args,**kwargs): #变
print(‘这是xx权限验证’)
return func(*args,**kwargs)
return call_func @add_qx
@add_xx
def test1():
print(‘——test1——-’)

test1()

首先执行第一个,但是第一个装饰器下面不是函数(装饰器原则:下面必须是函数,否则不执行),所以第一个函数先等待,等第二个装饰器执行后形成函数在交给第一个装饰器;所以运行结果是:

  1. 开始进行装饰xx的功能,

  2. 开始进行装饰权限1,

  3. 这是权限验证1,

  4. 这是xx权限验证,

  5. ——-test1——-,

——————装饰器练习—————- 输出格式:<td><h1>haha</h1></td>

 def set_func_1(func):
def call_func():
return ‘<h1>’ + func() + ’</h1>’
return call_func ​
def set_func_2(func):
def call_func():
return ‘<td>’ + func() + ’</td>’
return call_func @set_func_1()
@set_func_2()
def get_str():
return ‘haha’ print(get_str()) 最后执行的效果: <h1><td>haha</td></h1>
6. 用类对函数进行装饰(了解):
 class Test(object):
def __init__(self,func):
self.func = fun def __call__(self):
print(‘这里是装饰器的功能。。。。’)
return self.func() @Test
def get_str():
return ‘haha’ print(get_str())

以上就是装饰器与闭包的全部内容,希望有所收获,如果有错误,希望指出,感谢!!

python高级-闭包-装饰器的更多相关文章

  1. python高级之装饰器

    python高级之装饰器 本节内容 高阶函数 嵌套函数及闭包 装饰器 装饰器带参数 装饰器的嵌套 functools.wraps模块 递归函数被装饰 1.高阶函数 高阶函数的定义: 满足下面两个条件之 ...

  2. 第二篇:python高级之装饰器

    python高级之装饰器   python高级之装饰器 本节内容 高阶函数 嵌套函数及闭包 装饰器 装饰器带参数 装饰器的嵌套 functools.wraps模块 递归函数被装饰 1.高阶函数 高阶函 ...

  3. python函数闭包-装饰器-03

    可调用对象 callable()  # 可调用的(这个东西加括号可以执行特定的功能,类和函数) 可调用对象即  callable(对象)  返回为  True  的对象 x = 1 print(cal ...

  4. 【Python】 闭包&装饰器

    python中的函数本身就是对象,所以可以作为参数拿来传递.同时其允许函数的层级嵌套定义,使得灵活性大大增加. 闭包 闭包的定义:将函数的语句块与其运行所需要的环境打包到一起,得到的就是闭包对象.比如 ...

  5. 网络编程-Python高级语法-装饰器

    理论:装饰器就是运行一个函数之前首先运行装饰器函数,python装饰器就是用于拓展原来函数功能的一种函数,这个函数的特殊之处在于它的返回值也是一个函数,使用python装饰器的好处就是在不用更改原函数 ...

  6. python之闭包+装饰器

    闭包 内部函数对外部函数作用域变量的引用. 函数内的属性都是有生命周期的,都是在函数执行期间 闭包内的闭包函数私有化了变量,类似于面向对象 图片解析 示例一 https://www.bilibili. ...

  7. Day11 Python基础之装饰器(高级函数)(九)

    在python中,装饰器.生成器和迭代器是特别重要的高级函数   https://www.cnblogs.com/yuanchenqi/articles/5830025.html 装饰器 1.如果说装 ...

  8. Python深入05 装饰器

    作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 装饰器(decorator)是一种高级Python语法.装饰器可以对一个函数.方法 ...

  9. 【Python】【装饰器】

    Python中的装饰器是你进入Python大门的一道坎,不管你跨不跨过去它都在那里. 为什么需要装饰器 我们假设你的程序实现了say_hello()和say_goodbye()两个函数. def sa ...

随机推荐

  1. 一、Redis 总结

    官网 Redis 介绍 Redis 是一个开源的.支持网络.可基于内存亦可持久化的日志型.Key-Value 数据库,并提供多种语言的 API. Redis 是一个 key-value 存储系统.为了 ...

  2. CentOS8的网络管理变化

    资料来源: https://www.cnblogs.com/linuxandy/p/10839856.html 1.CentOS8使用NetworkManager.service(简称NM)来管理网络 ...

  3. Keycloak快速上手指南,只需10分钟即可接入Spring Boot/Vue前后端分离应用实现SSO单点登录

    登录及身份认证是现代web应用最基本的功能之一,对于企业内部的系统,多个系统往往希望有一套SSO服务对企业用户的登录及身份认证进行统一的管理,提升用户同时使用多个系统的体验,Keycloak正是为此种 ...

  4. Rocket - util - LanePositionedQueue

    https://mp.weixin.qq.com/s/yO_9Ec3S5-AosRVLpsBgOg   简单介绍基于通道位置的队列(LanePositionedQueue)的实现.   ​​   1. ...

  5. Nginx 笔记(三)nginx 配置实例 - 反向代理、负载均衡、动静分离

    个人博客网:https://wushaopei.github.io/    (你想要这里多有) 一.反向代理 反向代理准备工作: (1)在 liunx 系统安装 tomcat,使用默认端口 8080 ...

  6. Java实现 LeetCode 371 两整数之和

    371. 两整数之和 不使用运算符 + 和 - ​​​​​​​,计算两整数 ​​​​​​​a .b ​​​​​​​之和. 示例 1: 输入: a = 1, b = 2 输出: 3 示例 2: 输入: ...

  7. Java实现 计蒜客 1251 仙岛求药

    仙岛求药 少年李逍遥的婶婶病了,王小虎介绍他去一趟仙灵岛,向仙女姐姐要仙丹救婶婶.叛逆但孝顺的李逍遥闯进了仙灵岛,克服了千险万难来到岛的中心,发现仙药摆在了迷阵的深处.迷阵由 M \times NM× ...

  8. Java实现LeetCode_0012_IntegerToRoman

    package javaLeetCode.primary; import java.util.Scanner; public class IntegerToRoman_12 { public stat ...

  9. java实现拼出漂亮的表格

    /* * 在中文 Windows 环境下,控制台窗口中也可以用特殊符号拼出漂亮的表格来. 比如: ┌─┬─┐ │ │ │ ├─┼─┤ │ │ │ └─┴─┘ 其实,它是由如下的符号拼接的: 左上 = ...

  10. Java实现 蓝桥杯 算法提高 扶老奶奶过街

    1 问题描述 一共有5个红领巾,编号分别为A.B.C.D.E,老奶奶被他们其中一个扶过了马路. 五个红领巾各自说话: A :我和E都没有扶老奶奶 B :老奶奶是被C和E其中一个扶过大街的 C :老奶奶 ...