为了账号安全,请及时绑定邮箱和手机立即绑定

请问有人能帮我解析一下这段代码吗?

请问有人能帮我解析一下这段代码吗?

中间有好多都看不懂

import time

def performance(f):

   def fn(*args, **kw):

       t1 = time.time()

       r = f(*args, **kw)

       t2 = time.time()

       print 'call %s() in %fs' % (f._name_, (t2 - t1))

       return r

   return fn

正在回答

2 回答

第一行,导入模块time

第二行,定义一个叫performance的函数,接收一个参数

第三行,定义一个函数,接收任何参数

第四行,调用time模块的time方法,得到系统当前时间的时间戳

第五行,调用函数f,这个f函数就是传递给performance函数的参数,且f函数接收任何参数

第六行,再次调用time模块的time方法,获得当前时间的时间戳

第七行,打印调用的函数名,和调用函数的前后时间差(用到了字符串的占位符,可看一下python中的格式化字符串)

第八行,返回f函数的调用结果

第九行,返回新定义的函数fn

综上:函数performance接收一个函数作为参数,对这个函数进行包装,返回一个新函数

12 回复 有任何疑惑可以回复我~
#1

Liaobaozai 提问者

非常感谢!
2017-09-14 回复 有任何疑惑可以回复我~

这个函数最后返回fn,就是说这个函数的返回值最终会指向一个函数,就是这个fn。

这个fn的意思就是调用了f,并返回了f的值,这样这个函数就没有改变原有函数的功能。只是在f的前后加上了时间,这样就可以打印f调用时间日志了。

你可以看下装饰器那一节


2 回复 有任何疑惑可以回复我~
#1

慕移动6447889

请问为什么第八行要返回r
2017-10-17 回复 有任何疑惑可以回复我~
#2

慕运维8667833 回复 慕移动6447889

return r 就是return f(*args,**kw)吧
2017-11-06 回复 有任何疑惑可以回复我~
#3

qq_清蒸红烧_03602510 回复 慕移动6447889

return r,返回的是r = f(*args, **kw)的值,但因为这道习题里不需要这个函数的值,所以这道题里删掉return r也不影响运行结果
2017-12-29 回复 有任何疑惑可以回复我~
#4

慕移动6447889 回复 qq_清蒸红烧_03602510

明白,谢谢你
2018-01-02 回复 有任何疑惑可以回复我~
#5

慕移动6447889 回复 qq_清蒸红烧_03602510

明白,谢谢你
2018-01-02 回复 有任何疑惑可以回复我~
#6

慕后端7295579 回复 慕移动6447889

因为装饰器的作用是在不改变原函数的功能前提下 附加新的功能 那么必须要运行原函数f 并且返回原函数f的值才可以 ,所以fn要返回 r (也就是运行f后的值)。
2018-02-09 回复 有任何疑惑可以回复我~
#7

慕移动6447889 回复 qq_清蒸红烧_03602510

thx
2018-02-12 回复 有任何疑惑可以回复我~
查看4条回复

举报

0/150
提交
取消
python进阶
  • 参与学习       255665    人
  • 解答问题       2949    个

学习函数式、模块和面向对象编程,掌握Python高级程序设计

进入课程

请问有人能帮我解析一下这段代码吗?

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信