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

免费个人简历关键词排名优化公司

免费个人简历,关键词排名优化公司,网站建设行业咨讯文章,wordpress页面类型🧩 Python小练习系列 Vol.13:用装饰器记录函数执行时间 本节是 Python 小练习系列的一个子题,带你理解并动手写出一个能实用、可拓展的装饰器。 🎯 练习目标 理解 Python 装饰器(Decorator)的工作原理&…

🧩 Python小练习系列 Vol.13:用装饰器记录函数执行时间

本节是 Python 小练习系列的一个子题,带你理解并动手写出一个能实用、可拓展的装饰器。


🎯 练习目标

  • 理解 Python 装饰器(Decorator)的工作原理;
  • 学会使用 @ 装饰器语法糖;
  • 编写一个记录函数运行时间的装饰器;
  • 掌握 functools.wraps 的正确使用方式;
  • 探索装饰器进阶应用场景。

🧠 一分钟理解什么是装饰器

“不改原函数的代码,就能给它增加功能?”

是的!装饰器是 Python 中的一种语法糖,它其实是一个返回函数的函数。装饰器常用于日志记录、权限验证、性能统计、缓存等场景。

举个例子:

def greet():print("Hello!")# 给 greet 函数加个装饰器:
def shout_decorator(func):def wrapper():print("Before call!")func()print("After call!")return wrappergreet = shout_decorator(greet)
greet()

输出:

Before call!
Hello!
After call!

换成语法糖的写法就是:

@shout_decorator
def greet():print("Hello!")

💡 我们的练习:计时装饰器 @timeit

目标功能:

  • @timeit 装饰任意函数;
  • 执行前记录函数名;
  • 执行后打印运行时间(精确到毫秒);
  • 返回原函数的执行结果。

🔧 步骤 1:基础版装饰器

import timedef timeit(func):def wrapper(*args, **kwargs):print(f"⏱ 正在执行函数: {func.__name__}")start = time.time()result = func(*args, **kwargs)end = time.time()print(f"✅ 函数 {func.__name__} 执行完成,用时 {end - start:.4f} 秒")return resultreturn wrapper

用法示例:

@timeit
def add(a, b):time.sleep(0.5)return a + bprint(add(10, 20))

输出:

⏱ 正在执行函数: add
✅ 函数 add 执行完成,用时 0.5003 秒
30

⚠️ 步骤 2:加入 functools.wraps 避免元信息丢失

import functoolsdef timeit(func):@functools.wraps(func)def wrapper(*args, **kwargs):print(f"⏱ 正在执行函数: {func.__name__}")start = time.time()result = func(*args, **kwargs)end = time.time()print(f"✅ 函数 {func.__name__} 执行完成,用时 {end - start:.4f} 秒")return resultreturn wrapper

🧪 步骤 3:再测几个函数

@timeit
def multiply(a, b):time.sleep(0.8)return a * b@timeit
def say_hello(name):print(f"Hello, {name}!")multiply(3, 4)
say_hello("Python")

🚀 进阶挑战(可选)

1. 参数化装饰器(带参数的装饰器)

def timeit(verbose=True):def decorator(func):@functools.wraps(func)def wrapper(*args, **kwargs):if verbose:print(f"⏱ 正在执行函数: {func.__name__}")start = time.time()result = func(*args, **kwargs)end = time.time()if verbose:print(f"✅ 函数 {func.__name__} 执行完成,用时 {end - start:.4f} 秒")return resultreturn wrapperreturn decorator@timeit(verbose=False)
def fast_add(a, b):return a + b

2. 装饰异步函数(使用 asyncio

import asynciodef async_timeit(func):@functools.wraps(func)async def wrapper(*args, **kwargs):start = time.time()result = await func(*args, **kwargs)end = time.time()print(f"✅ 异步函数 {func.__name__} 执行完成,用时 {end - start:.4f} 秒")return resultreturn wrapper@async_timeit
async def async_task():await asyncio.sleep(1)asyncio.run(async_task())

📌 总结

技能点说明
@装饰器增强函数功能的利器
*args, **kwargs保证适配各种函数参数
functools.wraps保持原函数元信息
参数化装饰器更加灵活的扩展方式
异步函数装饰器用于 async def 函数的异步装饰器

📚 推荐练习拓展

  • 写一个权限检查装饰器(只允许 admin 用户执行函数);
  • 写一个函数缓存装饰器(简单 LRU 缓存);
  • 写一个失败自动重试的装饰器(异常自动重试 N 次);
  • 把多个装饰器组合使用,看函数执行顺序。

如果这篇内容对你有帮助,
欢迎 点赞 👍 | 收藏 ⭐ | 关注 ❤️
如果你有更好的想法,欢迎评论区留言分享~

http://www.dtcms.com/wzjs/511249.html

相关文章:

  • 做一个招聘信息的网站_用什么做网站的软件企业查询免费
  • 网站会员注册系统下载体球网足球世界杯
  • 原创网站模版互联网营销师考试题库
  • 2024年b站推广入口大全哪里的网络推广培训好
  • 在百度上做购物网站百度的总部在哪里
  • 网站建设的目的和目标外贸软件排行榜
  • 怎样围绕网站专题发展来做ppt泰州网站整站优化
  • 简述无线网络优化的流程seo网站结构优化
  • 网站psd模版站长网站大全
  • 杭州教育网站建设百度上做推广怎么做
  • 重庆大渡口营销型网站建设公司推荐北京搜索引擎优化
  • 麦吉太原网站建设丽怎么代理seo云优化如何
  • 深圳市宝安区做网站建设的企业软文素材网站
  • 微信怎样建网站百度app广告
  • 网上商城是什么seo系统培训
  • 营销网站建设大概费用最近实时热点事件
  • 网站建设验收合格确认书同城推广平台
  • 深圳网站设计 制作元seo优质友链购买
  • 业网站制作谁有恶意点击软件
  • 付费网站源码沈阳百度seo关键词优化排名
  • 广州美容网站建设企业网搭建
  • 久久网站建设微信广告平台
  • 网站建设项目需求费用搜索引擎优化方式
  • wordpress本地网站怎么搬到服务器日本产品和韩国产品哪个好
  • 十堰微网站建设价格整合营销策略
  • 珠海做网站疫情最新政策最新消息
  • 青岛网站建设维护网站信息
  • 北京住房建设官方网站信息流广告是什么
  • 页面设计心得体会青岛seo经理
  • 永川网站制作联系电话福州短视频seo