当前位置: 首页 > news >正文

python 方法运行计时装饰模式实现

在代码开发过程中,需要记录方法的执行时间,每个方法都硬代码也可以实现,但是不是最好的方式,考虑到设计模式和模版代码,通过装饰模式实现方法运行计时

在Python中,装饰器可以接受参数,这样可以使装饰器更加灵活,能够根据不同的参数来调整其行为。要给timer装饰器增加特定参数,可以采用多层嵌套函数的方式来实现。下面是一个示例,展示如何给timer装饰器增加一个参数,例如单位(秒或毫秒):

import timedef timer(unit="seconds"):"""A decorator factory that creates a timer decorator with a specified unit."""def decorator(func):"""The actual timer decorator that wraps the function."""def wrapper(*args, **kwargs):start_time = time.time()result = func(*args, **kwargs)end_time = time.time()elapsed_time = (end_time - start_time) * (1000 if unit == "milliseconds" else 1)print(f"{func.__name__} executed in {elapsed_time:.4f} {unit}")return resultreturn wrapperreturn decorator# 使用装饰器,指定单位为毫秒
@timer(unit="milliseconds")
def my_function(n):# 假设这是一个耗时的操作time.sleep(n)# 调用函数
my_function(2)

在这个例子中,timer装饰器工厂接受一个参数unit,它决定计时单位是秒还是毫秒。decorator函数是真正的装饰器,它接受待装饰的函数func作为参数,并返回一个包装后的函数wrapperwrapper函数计算函数的执行时间,并根据unit参数将其转换为毫秒或保持为秒。

要使用带有特定参数的装饰器,你只需在@decorator语法前面加上参数即可,如@timer(unit="milliseconds")

这种方式使得timer装饰器可以根据不同的需求进行定制,比如计时单位的选择,甚至可以进一步扩展,加入更多的参数,如是否输出日志日志级别等,从而满足更复杂的应用场景。

根据自己的需要选择合适的实现方式,利用设计模式减少模版代码和代码的重复率

http://www.lryc.cn/news/376397.html

相关文章:

  • 【权威出版/投稿优惠】2024年水利水电与能源环境科学国际会议(WRHEES 2024)
  • 阿赵UE引擎C++编程学习笔记——场景加载和切换
  • 【LLM之RAG】RAFT论文阅读笔记
  • 【Android】使用Binder(AIDL)实现利用自定义Bean进行的进程间通信(二)
  • HTTP中get与post的区别?在传输数据类型上有什么区别?【面试】
  • 「51媒体-年中大促」天津有哪些媒体资源-媒体宣传服务公司
  • Thinkphp校园新闻发布系统源码 毕业设计项目实例
  • 前端老古董execCommand——操作 选中文本 样式
  • elementui写一个自定义的rangeInput的组件
  • 护眼灯哪些牌子好?一文刨析护眼灯怎么选择!
  • 抖音短剧看剧系统是怎么做的?怎么样搭建上线运营?
  • 2024.06.06校招 实习 内推 面经
  • 神经网络模型---ResNet
  • Linux之网络编程
  • opencascade AIS_InteractiveContext源码学习1
  • TIA博途 WinCC下载到面板时,提示错误消息:“装载过程终止由于传输错误:8020AB001A06FFF4!”的解决办法
  • 【MySQL】聊聊数据库是如何保证数据不丢的
  • GitLab教程(四):分支(branch)和合并(merge)
  • 2021数学建模A题目–“FAST”主动反射面的形状调节
  • 华为---- RIP路由协议基本配置
  • Android studio在Ubuntu桌面上 创建桌面图标,以及导航栏图标
  • JAVA云HIS医院管理系统源码 云HIS系统的应用场景
  • Handler机制
  • 鸿蒙实现金刚区效果
  • Ubuntu 查看设备温度
  • 大型网站优化指南:打造流畅的在线体验
  • Redis变慢了?
  • 11.6.k8s实战-节点扩缩容
  • 相亲交友APP系统|婚恋交友社交软件|语音聊天平台定制开发
  • 2005-2022年款福特福克斯维修手册和电路图线路图接线图资料更新