# 装饰器的形成的过程:最简单的装饰器;有返回值的;有一个参数的;万能参数
# 装饰器的作用
# 原则:开放封闭原则
# 语法糖
# 装饰器的固定模式:
# def wrapper(f): # 装饰器函数,f是被装饰的函数
# def inner(*args,**kwargs):
# '''在被装饰函数之前要做的事'''
# res = f(*args,**kwargs) # 被装饰的函数
# '''在被装饰函数之后要做的事'''
# return res
# return inner import time
# print(time.time()) # 获取当前时间
# time.sleep(5) # 让程序在执行到这个位置的时候停一会 # def func():
# '''
# 计算程序运行所用时间
# :return: 程序运行时间
# '''
# start = time.time()
# print('老板好,同事好,大家好')
# time.sleep(0.01)
# end = time.time()
# print(end - start)
# func() # def timer(f): # 专门写一个函数,计算函数执行时间
# start = time.time()
# f()
# end = time.time()
# print(end - start)
# def func():
# time.sleep(0.01)
# print('老板好,同事好,大家好')
# timer(func) # def timer(f): # 装饰器函数
# def inner():
# start = time.time()
# res = f() # 被装饰的函数
# end = time.time()
# print(end - start)
# return res
# return inner
# @timer # 等于func = timer(func) 语法糖, @装饰器函数名,紧跟被装饰的函数
# def func(): # 被装饰的函数
# time.sleep(0.01)
# print('老板好,同事好,大家好')
# return '新年好'
# # func = timer(func)
# res = func()
# print(res) # 装饰器的作用:不想修改函数的调用方式, 但是还想在原来的函数前后添加功能
# timer就是一个装饰器函数,只是对一个函数 有一些装饰作用 # 原则:开放封闭原则
# 开放:对扩展是开放的
# 封闭:读修改是封闭的 #
# def outer():
# def inner():
# return 'inner'
# inner()
# outer()
#---------------------------------------------------------------------------------------------------------------- # 装饰带参数函数的装饰器
# def timer(f): # 装饰器函数
# def inner(*args,**kwargs):
# start = time.time()
# res = f(*args,**kwargs) # 被装饰的函数
# end = time.time()
# print(end - start)
# return res
# return inner
# @timer # 等于func = timer(func) 语法糖, @装饰器函数名,紧跟被装饰的函数
# def func(a,b): # 被装饰的函数
# time.sleep(0.01)
# print('老板好,同事好,大家好',a,b)
# return '新年好'
#
# @timer
# def func1(a): # 被装饰的函数
# time.sleep(0.01)
# print('老板好,同事好,大家好',a)
# return '新年好'
# res = func(1,b = 2)
# ret = func1(1)
# print(res,ret) #--------------------------------------------------------------------------------------------------------
def wrapper(f): # 装饰器函数,f是被装饰的函数
def inner(*args,**kwargs):
'''在被装饰函数之前要做的事'''
res = f(*args,**kwargs) # 被装饰的函数
'''在被装饰函数之后要做的事'''
return res
return inner @wrapper
def func(a,b): # 被装饰的函数
time.sleep(0.01)
print('老板好,同事好,大家好',a,b)
return '新年好'
res = func(1,b = 2)
print(res)

python学习之老男孩python全栈第九期_day011知识点总结的更多相关文章

  1. python学习之老男孩python全栈第九期_day027知识点总结——反射、类的内置方法

    一. 反射 ''' # isinstance class A:pass class B(A):pass a = A() print(isinstance(a,A)) # 判断对象和类的关系 print ...

  2. python学习之老男孩python全栈第九期_day023知识点总结——类和对象命名空间、组合

    一. 类和对象命名空间类里 可以定义两种属性: 1. 静态属性 2. 动态属性 class Course: language = 'Chinese' def __init__(self, teache ...

  3. python学习之老男孩python全栈第九期_day019知识点总结——collections模块、时间模块、random模块、os模块、sys模块

    一. collections模块 在内置数据类型(dict.list.set.tuple)的基础上,collections模块还提供了几个额外的数据类型:namedtuple.deque.Counte ...

  4. python学习之老男孩python全栈第九期_day017知识点总结——初识递归、算法

    一. 递归函数 如果一个函数在内部调用自身本身,这个函数就是递归函数. 最大递归深度默认是997 -- python从内存角度出发做得限制(而不是程序真的报错),最大深度可以修改 def func(n ...

  5. python学习之老男孩python全栈第九期_day010知识点总结

    def qqxing(l = []): # 可变数据类型 l.append(1) print(l)qqxing() # [1]qqxing([]) # [1]qqxing() # [1, 1]qqxi ...

  6. python学习之老男孩python全栈第九期_day007知识点总结

    基础数据类型汇总 1. str 2. int 3. list 4. bool 5. dict (1) fromkeys Python 字典 fromkeys() 方法用于创建一个新的字典,并以可迭代对 ...

  7. python学习之老男孩python全栈第九期_day001知识点总结

    1. Python2与Python3的区别: Python2:源码不标准,混乱,重复代码太多: Python3:统一标准,去除重复代码. 编码方式: python2的默认编码方式为ASCII码:pyt ...

  8. python学习之老男孩python全栈第九期_day014知识点总结

    # 迭代器和生成器# 迭代器 # 双下方法:很少直接调用的方法,一般情况下,是通过其他语法触发的# 可迭代的 --> 可迭代协议:含有__iter__的方法( '__iter__' in dir ...

  9. python学习之老男孩python全栈第九期_day016知识点总结

    '''数据类型:intbool... 数据结构:dict (python独有的)listtuple (pytho独有的)setstr''' # reverse() 反转l = [1,2,3,4,5]l ...

随机推荐

  1. vue+iview实现一行平均五列布局

    iview 的栅格布局是以 html代码部分: <Row :gutter="20"> <Col style="float: left;width: 20 ...

  2. h5文字超出,两行显示,超出显示省略号

    最近接到一个需求,要求商场导航里的文字最多显示两行,超出两行的省略号显示,查一些资料,又根据自己的需求,改了很多,直接上代码吧 <html> <head> <style ...

  3. [翻译] Trident-ML:基于storm的实时在线机器学习库

    最近在看一些在线机器学习的东西,看到了trident-ml, 觉得比较有意思,就翻译了一下,方便有兴趣的读者学习. 本文为作者(掰棒子熊)翻译自https://github.com/pmerienne ...

  4. Spark中的常用算子

    更多有用的例子和算子讲解参见: http://homepage.cs.latrobe.edu.au/zhe/ZhenHeSparkRDDAPIExamples.html map是对每个元素操作, ma ...

  5. Android的Fragment的第一种声明方式

    Android的Frangment的第一种声明方式 实际效果图如下: 项目结构图如下: fragment1: package com.demo.fragementfirst; import andro ...

  6. volatile双重检查锁定与延迟初始化

    一.基本概念: 1.volatile是轻量级的synchronized,在多核处理器开发中保证了共享变量的“可见性”.可见性的意思是,当一个线程修改一个共享变量时,另一个线程能读到这个修改的值. 2. ...

  7. Android_EditText 打勾显示输入的密码 --EditText与setTransformationMethod

    实现目标: 实现原理: 为CheckBox添加一个监听器事件; 实现的源码: package edu.cquptzx.showPassword; import android.app.Activity ...

  8. Hadoop2源码分析-序列化篇

    1.概述 上一篇我们了解了MapReduce的相关流程,包含MapReduce V2的重构思路,新的设计架构,与MapReduce V1的区别等内容,今天我们在来学习下在Hadoop V2中的序列化的 ...

  9. 【详解】ThreadPoolExecutor源码阅读(一)

    系列目录 [详解]ThreadPoolExecutor源码阅读(一) [详解]ThreadPoolExecutor源码阅读(二) [详解]ThreadPoolExecutor源码阅读(三) 工作原理简 ...

  10. 前端模块化之CommonJS,ES6,AMD,CMD

    最近在搞跨平台解决方案,讨论关于模块划分的问题以及如何尽量多的复用逻辑代码.于是就有了此文章,之前的博客也写过,不过由于主机商跑路,宝贵的资源也就没了,说多了都是泪~ 这里按模块化发展的历史回溯的时间 ...