1. 需求

开发封闭原则:虽然在这个原则是用的面向对象开发,但是也适用于函数式编程,简单来说,它规定已经实现的功能代码不允许被修改,但可以被拓展,即:

  • 封闭:已实现的功能代码块
  • 开发:对拓展开发

2. 使用装饰器

2.1 未使用装饰器(原理)

def w1(func):
def inner():
# 验证1
# 验证2
# 验证3
print("----正在验证权限----")
func()
return inner def f1():
print("---f1----") def f2():
print("---f2----") f1 = w1(f1) f1()

----正在验证权限----
---f1----

2.2 使用装饰器

def w1(func):
def inner():
# 验证1
# 验证2
# 验证3
print("----正在验证权限----")
func()
return inner @w1
def f1():
print("---f1----") @w1
def f2():
print("---f2----") f1()
f2()

----正在验证权限----
---f1----
----正在验证权限----
---f2----

3. 再议装饰器

# 定义函数:完成包裹数据
def makeBold(fn):
def wrapped():
print("-----1------")
return "<b>" + fn() + "</b>"
return wrapped # 定义函数:完成包裹数据
def makeItalic(fn):
def wrapped():
print("-----2------")
return "<i>" + fn() + "</i>"
return wrapped @makeBold
@makeItalic
def test3():
print("-----3-----")
return "hello world" s = test3()
print(s)

-----1------
-----2------
-----3-----
<b><i>hello world</i></b>

4. 装饰器执行时间

@w1
def f1():
print("---f1----")

只要Python解释器执行到了这个代码 ,那么就会自动的进行装饰,而不是等到调用的时候才装饰

5. 装饰器对有参数、无参数函数进行装饰

5.1 无参数

def func(functionName):
print("-----func----1-----")
def func_in():
print("---func_in----1----")
functionName()
print("---func_in----2----") print("-----func----2-----")
return func_in @func
def test():
print("----test------") test()

-----func----1-----
-----func----2-----
---func_in----1----
----test------
---func_in----2----

5.2 函数有参数

def func(functionName):
print("-----func----1-----")
def func_in(aa, bb):
print("---func_in----1----")
functionName(aa, bb)
print("---func_in----2----") print("-----func----2-----")
return func_in @func
def test(a, b):
print("----test---a=%d---b=%d---" %(a, b)) test(11, 22)

-----func----1-----
-----func----2-----
---func_in----1----
----test---a=11---b=22---
---func_in----2----

5.3 函数有不定参数

def func(functionName):
print("-----func----1-----")
def func_in(*args, **kargs):
print("---func_in----1----")
functionName(*args, **kargs)
print("---func_in----2----") print("-----func----2-----")
return func_in @func
def test(a, b, c):
print("----test---a=%d---b=%d---c=%d-------" %(a, b, c)) test(11, 22, 33)

-----func----1-----
-----func----2-----
---func_in----1----
----test---a=11---b=22---c=33-------
---func_in----2----

5.4 函数有返回值

def func(functionName):
print("-----func----1-----")
def func_in(*args, **kargs):
print("---func_in----1----")
res = functionName(*args, **kargs)
print("---func_in----2----")
return res print("-----func----2-----")
return func_in @func
def test(a, b, c):
print("----test---a=%d---b=%d---c=%d-------" %(a, b, c))
return "hahaha" res = test(11, 22, 33)
print("res: ", res)

-----func----1-----
-----func----2-----
---func_in----1----
----test---a=11---b=22---c=33-------
---func_in----2----
res: hahaha

6. 通用的装饰器

核心代码:

def func(functionName):
print("-----func----1-----")
def func_in(*args, **kargs):
print("---func_in----1----")
res = functionName(*args, **kargs)
print("---func_in----2----")
return res print("-----func----2-----")
return func_in

验证:

def func(functionName):
print("-----func----1-----")
def func_in(*args, **kargs):
print("---func_in----1----")
res = functionName(*args, **kargs)
print("---func_in----2----")
return res print("-----func----2-----")
return func_in @func
def test(a, b, c):
print("----test---a=%d---b=%d---c=%d-------" %(a, b, c))
return "hahaha" @func
def test2(a):
print("-----test2---%d---"%a) res = test(11, 22, 33)
print("res: ", res) test2(3)

-----func----1-----
-----func----2-----
-----func----1-----
-----func----2-----
---func_in----1----
----test---a=11---b=22---c=33-------
---func_in----2----
res: hahaha
---func_in----1----
-----test2---3---
---func_in----2----

7. 装饰器有参数

from time import ctime, sleep

def timefun_arg(pre="hello"):
def timefun(func):
def wrappedfunc():
print("%s called at %s %s" %(func.__name__, ctime(), pre))
return func()
return wrappedfunc
return timefun @timefun_arg("douzi")
def foo():
print("I am foo") @timefun_arg("python")
def too():
print("I am too") foo()
sleep(2)
too()

foo called at Thu May 9 00:57:58 2019 douzi
I am foo
too called at Thu May 9 00:58:00 2019 python
I am too

8. 综合

from time import ctime, sleep

def timefun_arg(pre="hello"):
print("fun_1")
def timefun(func):
print("fun_in_1")
def wrappedfunc(*args, **kwargs):
print("%s called at %s %s" %(func.__name__, ctime(), pre))
return func(*args, **kwargs)
print("fun_in_2")
return wrappedfunc
print("fun_2")
return timefun @timefun_arg("douzi")
def foo(fname):
print(fname, "I am foo") @timefun_arg("python")
def too():
print("I am too") foo("fname ")
sleep(2)
too()

Python高级笔记(十一)装饰器【面试】的更多相关文章

  1. Python学习笔记012——装饰器

    1 装饰器 1.1装饰器定义 在代码运行期间动态增加功能的方式,称之为“装饰器”(Decorator). 1.2 装饰器分类 装饰器:函数装饰器,类装饰器,函数的装饰器,类的装饰器 装饰器:函数装饰函 ...

  2. Python学习笔记:装饰器

    Python 装饰器的基本概念和应用 代码编写要遵循开放封闭原则,虽然在这个原则是用的面向对象开发,但是也适用于函数式编程,简单来说,它规定已经实现的功能代码不允许被修改,但可以被扩展,即: 封闭:已 ...

  3. python高级编程之装饰器04

    from __future__ import with_statement # -*- coding: utf-8 -*- # python:2.x __author__ = 'Administrat ...

  4. python学习笔记:装饰器2

    python的装饰器本质是函数,为了不改变装饰目标函数内部代码而增加额外功能而存在 一.一般装饰函数实例: import datetime def func_name(func):#定义一个装饰函数, ...

  5. Python高级--闭包与装饰器

    前言:在Python中,闭包是一种非常有用的功能!它通常与装饰器一起搭配使用,可以在不改变被装饰函数的功能的基础上,完成更多的功能.如权限认证. 一.如何定义闭包 1.闭包就是两个嵌套的函数,外层函数 ...

  6. python学习笔记(五):装饰器、生成器、内置函数、json

    一.装饰器 装饰器,这个器就是函数的意思,连起来,就是装饰函数,装饰器本身也是一个函数,它的作用是用来给其他函数添加新功能,比如说,我以前写了很多代码,系统已经上线了,但是性能比较不好,现在想把程序里 ...

  7. python学习笔记之装饰器、生成器、内置函数、json(五)

    一.装饰器 装饰器,这个器就是函数的意思,连起来,就是装饰函数,装饰器本身也是一个函数,它的作用是用来给其他函数添加新功能比如说,我以前写了很多代码,系统已经上线了,但是性能比较不好,现在想把程序里面 ...

  8. python学习笔记之装饰器、递归、算法(第四天)

    参考老师的博客: 金角:http://www.cnblogs.com/alex3714/articles/5161349.html 银角:http://www.cnblogs.com/wupeiqi/ ...

  9. Python学习笔记之装饰器原理

    def decorator(fn): def wrapper(): print("询价") fn() print("购买成功!") return wrapper ...

  10. python笔记 - day4-之装饰器

                 python笔记 - day4-之装饰器 需求: 给f1~f100增加个log: def outer(): #定义增加的log print("log") ...

随机推荐

  1. spring boot 过滤器、拦截器的区别与使用

    原文:https://blog.csdn.net/heweimingming/article/details/79993591 拦截器与过滤器的区别: 1.过滤器和拦截器触发时机不一样,过滤器是在请求 ...

  2. python代码安全扫描工具

    python代码安全扫描工具:Coverity. Fortify.SecMissile(漏扫,对源代码提供基于语义的搜索和分析能力,实现已知安全漏洞的快速扫描)

  3. selenium获取元素信息方法(转载)

    1.获取当前页面的Url函数 方法:current_url 实例: driver.current_url 2.获取元素坐标 方法:location 解释:首先查找到你要获取元素的,然后调用locati ...

  4. shortcuts for contructor 创建对象捷径

  5. StringTokenizer字符串分解器

    示例: StringTokenizer st = new StringTokenizer(key, ",", false); while (st.hasMoreTokens()) ...

  6. ora-00054资源正忙,但指定以nowait方式

    select l.session_id,o.owner,o.object_name from v$locked_object l,dba_objects o where l.object_id=o.o ...

  7. L1141(bfs思想)

    一,看 1,整个方格图其实可以看做是一些不连通的图. 当然图内部必然是联通的. 2,遍历的技巧没什么. 方格图入队的技巧..额,是这样的 int gtid(int x,int y) { return ...

  8. Java web开发——文件夹的上传和下载

    我们平时经常做的是上传文件,上传文件夹与上传文件类似,但也有一些不同之处,这次做了上传文件夹就记录下以备后用. 这次项目的需求: 支持大文件的上传和续传,要求续传支持所有浏览器,包括ie6,ie7,i ...

  9. 2019.12.07 java计算

    class Demo05{ public static void main(String[] args) { int a=1; a++; int b=1 + a++ + a + a++; System ...

  10. openjdk k8s port-forward 连接容器jmx服务

    jmx 是java 自带的,如果需要使用我们只需要添加对应的配置即可,以下演示docker 集成jmx 使用kompose 生成k8s 的部署文件,使用port-forward 进行连接,所以java ...