linux中的加法函数,上下文管理练习(为加法函数计时)

上下文管理(为加法函数计时)

为加法函数计时

使用装饰器显示该函数的执行时长

使用上下文管理显示该函数的执行时长

装饰器实现

import time

import datetime

from functools import wraps

def logger(fn):

@wraps(fn) # wraps(fn)(wrapper)

def wrapper(*args, **kw):

start = datetime.datetime.now()

ret = fn(*args, **kw)

delta = (datetime.datetime.now() - start).total_seconds()

print(delta)

return ret

return wrapper

@logger

def add(x, y):

time.sleep(2)

return x + y

上下文实现

最简单实现

3c8ce6380daa33c267ccb0e2e66a02de.png

增加__call__用法

import time

import datetime

class TimeIt:

def __init__(self, fn):

self.fn = fn

def __enter__(self):

self.start = datetime.datetime.now()

return self

def __exit__(self, exc_type, exc_val, exc_tb):

self.delta = (datetime.datetime.now() - self.start).total_seconds()

print(self.delta)

def __call__(self, *args, **kwargs):

ret = self.fn(*args, **kwargs)

return ret

def add(x, y):

""" This is add"""

time.sleep(2)

return x + y

with TimeIt(add) as foo:

print(foo(3,4))

3c8ce6380daa33c267ccb0e2e66a02de.png

需要增加初始化方法,为下面__call__使用

__enter__方法返回self是为了,有了__call__方法以后,可以这样使用with TimeIt(add) as foo: foo(3,4)

因为有了__call__后,实例变成可调用,而foo就是实例化后的实例

TimeIt(add)是将add函数名作为形参传进去

改成装饰器

import time

import datetime

class TimeIt:

def __init__(self, fn):

self.fn = fn

def __enter__(self):

self.start = datetime.datetime.now()

return self

def __exit__(self, exc_type, exc_val, exc_tb):

self.delta = (datetime.datetime.now() - self.start).total_seconds()

print(self.delta)

def __call__(self, *args, **kwargs):

print('call')

ret = self.fn(*args, **kwargs)

return ret

@TimeIt # add = TimeIt(add)

def add(x, y):

""" This is add"""

time.sleep(2)

return x + y

# 上下文用法

# with TimeIt(add) as foo:

# print(foo(3,4))

print(add(5,6))

print(add.__doc__)

print(add.__dict__)

print(add.__name__)

3c8ce6380daa33c267ccb0e2e66a02de.png

3c8ce6380daa33c267ccb0e2e66a02de.png

装饰器用法很简单,直接在add函数上加个@TimeIt

这是由于@TimeIt等价于add = TimeIt(add),把add函数名作为实参传入到TimeIt类中

就相当于为add函数加了一个类封装的功能或属性

而这个时候,我们发现,用装饰器实现后,直接走的是__call__方法中的语句块,而上下文没有执行(因为没有用with..as语句)

也就是说,要么用with..as语句,要么用装饰器方法,这是两个方法

(用with..as语句执行装饰器方法,这样比较繁琐,重复计算,因题而异)

但是,如何解决文档字符串的问题,怎么把add函数的配置信息也弄过来(看__doc__和__dict__就可以知道)

解决文档字符串问题

方法1

把函数对象的文档字符串赋给类

class TimeIt:

def __init__(self, fn):

self.fn = fn

self.__doc__ = self.fn.__doc__

self.__name__ = self.fn.__name__

self.__dict__ = self.fn.__dict__

方法2

使用functools.wraps函数

最终完整版

import time

import datetime

from functools import wraps

class TimeIt:

"""This is Class"""

def __init__(self, fn):

self.fn = fn

# 把函数对象的文档字符串赋给类

# self.__doc__ = self.fn.__doc__

# self.__name__ = self.fn.__name__

# @wraps = wraps(fn)(wrapper)

wraps(fn)(self) # wraps用法

# def __enter__(self):

# self.start = datetime.datetime.now()

# return self

# def __exit__(self, exc_type, exc_val, exc_tb):

# self.delta = (datetime.datetime.now() - self.start).total_seconds()

# print(self.delta)

def __call__(self, *args, **kwargs):

print('call')

self.start = datetime.datetime.now()

ret = self.fn(*args, **kwargs)

delta = (datetime.datetime.now() - self.start).total_seconds()

print(delta)

return ret

@TimeIt # add = TimeIt(add)

def add(x, y):

""" This is add"""

time.sleep(2)

return x + y

# 上下文用法

# with TimeIt(add) as foo:

# print(foo(3,4))

print(add(5,6))

print(add.__doc__)

print(add.__dict__)

print(add.__name__)

print(type(add))

3c8ce6380daa33c267ccb0e2e66a02de.png

3c8ce6380daa33c267ccb0e2e66a02de.png

第15行的用法wraps(fn)(self)是根据这个@wraps = wraps(fn)(wrapper)来的

@wraps是带参装饰器,fn就是带参,wrapper是传入的实参

简单来说,@wraps = wraps(fn)(wrapper)就是把fn的配置信息赋值给wrapper

所以wraps(fn)(self)就是把fn的配置信息赋值给实例(self就是实例化后的实例)

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/88584

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/469928.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

07数组与接口

1、运行TextInherists.java 示例,观察输出,注意总结父类与子类之间构造方法的的调用关系,修改parent构造方法的代码,显式调用grandparent另一个构造函数。 源代码: class GrandParent{ public GrandParent(){ System.o…

windows 访问linux中的mongodb,MongoDB的linux系统下的安装与连接

一 安装MongoDB的服务下载Linux系统下的MongoDB安装包上传压缩包到linux服务器中,解压到对应的安装目录下mkdir /usr/local/mongodbtar -zxvf mongodb-linux-x86_64-4.0.10.tgzmv mongodb-linux-x86_64-4.0.10 /usr/local/mongodb新建目录,分别用来存储数…

linux sqlserver 管理工具,Linux连接SqlServer的图形化工具SQuirrel

SQuirrel SQL一款基于java的数据库管理工具。所以可以运行在任意平台上,除了界面丑一点。在windows上我绝对不会选的,navicat多好。安装下载地址:https://sourceforge.net/projects/squirrel-sql/?sourcetyp_redirect在控制台运行&#xff1…

JDK源码包结构分类

最近查看JDK源码时,无意间发现几个类在陌生包里:com.sun.*、sun.*、org.*,google了一把总结了下以备他人搜索,如内容有误欢迎指正!Jre库包含的jar文件(jdk1.6):resources.jar、rt.jar、jsse.jar、jce.jar、…

GJM :Sql 各种语句 以及函数 [转载]

版权声明:本文原创发表于 【请点击连接前往】 ,未经作者同意必须保留此段声明!如有侵权请联系我删帖处理!1.更改数据库的名称 2.表中有数据的情况下再添加列、删除列 3.在SQLServer 中各种查询语句的使用示例 4.模糊查询的语句 5.…

linux中断处理体系结构分析(一),Linux中断处理体系结构分析(二)

1.中断处理的体系结构我们知道编写设备驱动程序一定要用到中断处理函数,这在驱动程序的编写中,占据很重要的一部分。在响应一个特定的中断的时候,内核会执行一个函数,该函数叫做中断处理程序(interrupt handler)或中断服务例程(in…

c语言作业题五六章答案,数据结构(C语言版)第五六章习题答案

数据结构(C语言版)第五六章习题答案,人民邮电出版社,答案很详细。(15)设F是一个森林,B是由F变换得的二叉树。若F中有n个非终端结点,则B中右指针域为空的结点有( )个。A. n-1 B.n C. n1 D. n22.应…

Android中土司(Toast)的使用

Android中Toast的使用 什么是土司(Toast)? Toast是Android系统提供的一种非常好的提示方式,在程序中可以使用它将一些短小的信息通知给用户,这些信息会在一段时间后自动消失,并且不会占用任何的屏幕空间. 下面我们通过代码来体验一下土司在Android中的使用 1 import android.a…

atoll找不到标识符c语言,C/C++编程笔记:C++中的atol,atoll和atof函数

1、atol()此函数将作为参数传递给函数调用的C类型字符串转换为长整数。它解析C字符串str,将其内容解释为整数,并作为long int类型的值返回。该函数丢弃出现在字符串开头的空白字符,直到找到非空白字符为止。如果C字符串str中的非空白字符序列…

c语言指针改良,重新认识C语言指针(上)(示例代码)

? 独创性并不是首次观察某种新事物,而是把旧的、很早就是已知的,或者是人人都视而不见的事物当新事物观察,这才证明是有真正的独创头脑 —尼采本文已经收录至我的GitHub,欢迎大家踊跃star 和 issues。https://github.com/midou-tech/article…

HT68F30控制GPG96244QS1 TFT液晶屏

资料上显示是SPI总线控制、在SPENB由高变底的时候起动传输、由低到高的时候停止转输、并且传送的时候先传高位的数据、现在没有效果出来(正在找问题) 没有效果的意思是: 1、LCD屏没有图像、只有背光在亮 2、还没有找到一个寄存器或者一种方…

linux —— shell 编程(文本处理)

导读 本文为博文 linux —— shell 编程(整体框架与基础笔记)的第4小点的拓展。(本文所有语句的测试均在 Ubuntu 16.04 LTS 上进行) 目录基本文本处理流编辑器sedawk模式扫描与处理语言1、基本文本处理sort :用于排序,…

ub c语言,操作系统之LRU算法 C语言链表实现

LRU是Least Recently Used的缩写,即最近最少使用,是一种常用的页面置换算法,选择最近最久未使用的页面予以淘汰。该算法赋予每个页面一个访问字段,用来记录一个页面自上次被访问以来所经历的时间 t,当须淘汰一个页面时…

VMware 虚拟机 Ubuntu 系统执行 ifconfig 命令 eth0没有IP地址(intet addr、Bcast、Mask)

可能的原因是,你安装了也安装了其他的虚拟机软件,比如:VirtualBox。我们打开 控制面板 > 网络和共享中心 > 更改适配器设置 , 你就可以打开控制面板/网络和Internet/网络连接界面: 直接禁用相应的网络即可&#…

这本轻小说真厉害 2016

傲娇御坂美琴成轻小说女王一姐 轻小说排名公布 到了年底,作为轻小说的粉丝就没有理由不关注“这本轻小说真厉害!”的相关评选吧?腾讯动漫此前曾经报道过《OVERLORD》以及《龙王的工作》获得榜首殊荣的消息。而近日,年度的最佳作品、最佳角色以及最佳插画师等奖项也已经公布,快…

IDEA初次使用Tomcat运行项目(如何添加加载项目到Tomcat)

IDEA中Tomcat设置说明 Tomcat最好使用干净的版本 不同的版本适配不同的JDK 设置Tomcat基本信息 加载项目(war和war exploed模式简单说明) 配置完项目后警告消失 应用后启动 选择相应的模式即可

回溯算法背包问题迭代c语言,回溯法解决0_1背包问题(迭代和递归)

问题:0/1背包问题例子:weight数组代表物品重量,value数组代表物品价值,M代表背包容量。背包是按单位价值递减的顺序排列的,即value[i]/weight[i]>value[i-1]/weight[i-1].const int weight[Max]{1,11,21,23,33,43,45,55};const…

IDEA中中文乱码问题解决方案

1.修改idea安装目录下的两个文件 C:\Program Files\JetBrains\IntelliJ IDEA 2017.1.4\bin\idea.exe.vmoptions C:\Program Files\JetBrains\IntelliJ IDEA 2017.1.4\bin\idea64.exe.vmoptions 在这两个文件下增加一行: -Dfile.encodingUTF-8 2.做此修改后,tomcat运行日志会…

linux 6.2 期末考试题,redhat6.2-linux考试试卷(带部分答案)

这个是初学redhat6.2的考试内容,带答案(实做的,水平有限,不完整答案)--------------------------------------------------------------------------------------------装 订 线-----------------------------------------------------------------------------------------广东…