鱼C论坛

 找回密码
 立即注册
查看: 624|回复: 2

[已解决]装饰器

[复制链接]
发表于 2020-4-29 19:36:19 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
帮忙看看下面的代码!


import time
def fun_time(func):
    def print_time(*args):
        t1 = time.time()
        func(*args)
        t2 = time.time()
        print("运行时间为",t2-t1)

    return print_time

@print_time
def fib(n):
     if n==1 or n==2:
        return 1
     else:
        i,f1,f2 =2,1,1
        while(i<n):
            f3 = f1+f2
            f1 = f2
            f2 = f3
            i+=1
        print(f3)

fib(10000)

结果:<function __main__.print_time(func)>
最佳答案
2020-4-29 19:40:48
应该是 @fun_time 不是 @print_time 。代码帮你改好了:

  1. import time


  2. def fun_time(func):
  3.     def print_time(*args):
  4.         t1 = time.time()
  5.         func(*args)
  6.         t2 = time.time()
  7.         print("运行时间为", t2 - t1)

  8.     return print_time


  9. @fun_time
  10. def fib(n):
  11.     if n == 1 or n == 2:
  12.         return 1
  13.     else:
  14.         i, f1, f2 = 2, 1, 1
  15.         while i < n:
  16.             f3 = f1 + f2
  17.             f1 = f2
  18.             f2 = f3
  19.             i += 1
  20.         print(f3)


  21. fib(10000)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-4-29 19:38:32 | 显示全部楼层
我这里会报错,应该是这样吧
  1. import time
  2. def fun_time(func):
  3.     def print_time(*args):
  4.         t1 = time.time()
  5.         func(*args)
  6.         t2 = time.time()
  7.         print("运行时间为",t2-t1)

  8.     return print_time

  9. @fun_time
  10. def fib(n):
  11.      if n==1 or n==2:
  12.         return 1
  13.      else:
  14.         i,f1,f2 =2,1,1
  15.         while(i<n):
  16.             f3 = f1+f2
  17.             f1 = f2
  18.             f2 = f3
  19.             i+=1
  20.         print(f3)

  21. fib(10000)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-4-29 19:40:48 | 显示全部楼层    本楼为最佳答案   
应该是 @fun_time 不是 @print_time 。代码帮你改好了:

  1. import time


  2. def fun_time(func):
  3.     def print_time(*args):
  4.         t1 = time.time()
  5.         func(*args)
  6.         t2 = time.time()
  7.         print("运行时间为", t2 - t1)

  8.     return print_time


  9. @fun_time
  10. def fib(n):
  11.     if n == 1 or n == 2:
  12.         return 1
  13.     else:
  14.         i, f1, f2 = 2, 1, 1
  15.         while i < n:
  16.             f3 = f1 + f2
  17.             f1 = f2
  18.             f2 = f3
  19.             i += 1
  20.         print(f3)


  21. fib(10000)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-6-18 11:41

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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