鱼C论坛

 找回密码
 立即注册
查看: 3049|回复: 4

[已解决]帮忙看看装饰器为什么不起效

[复制链接]
发表于 2023-8-17 11:30:25 | 显示全部楼层
在你提供的代码中,装饰器似乎并没有起到预期的效果。这是因为在装饰器time_master中的内部函数call_func并没有被调用。为了使装饰器生效,你需要在定义call_func后立即调用它。

以下是修正后的代码示例:

  1. import time

  2. a = [10, 6, 8, 3, 7, 9, 1, 4, 2, 5]

  3. def time_master(func):
  4.     def call_func():
  5.         print("开始运行程序...")
  6.         start = time.time()
  7.         func()
  8.         stop = time.time()
  9.         print("结束运行程序...")
  10.         print("共耗时%s" % (stop - start))
  11.         
  12.     return call_func

  13. @time_master
  14. def iterSum():
  15.     s = 0
  16.     for i in range(len(a)):
  17.         s = s + a[ i]
  18.     return s

  19. iterSum()
复制代码


在修正后的代码中,我们将call_func作为内部函数返回,并在time_master装饰器上使用@将其应用于iterSum函数。这样,在调用iterSum函数时,实际上会调用被装饰后的call_func函数。

运行修正后的代码,你会看到输出结果包含了正确的耗时信息。

希望这能解决你的问题!如果还有其他疑问,请随时提问。
如果问题已经解决,请设置最佳答案
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-9-23 22:27

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表