Python - 装饰器

1 import time
2 def foo():
3     time.sleep(1)
4     print("foo.....")

 假设,这是一个在生产中正在使用的函数

公司老板让小明来实现一个功能,要求是给这个函数加上时间统计功能

小明马上就想到了解决的方法,并付诸行动。

小明的解决方案

小明想,这还不简单?马上给出了下面的代码

1 def foo():
2     start_time = time.time()
3     time.sleep(1)
4     print("foo.....")
5     end_time = time.time()
6     print("time:{}".format(end_time-start_time))

 

当小明修改完,问题出现了,很多部门都会使用这个函数,小明的修改导致了很多部门出现了问题

或者,小明的代码出现了bug,导致了整个公司的瘫痪

小明被开除

他的同事小刚被任命做小明没做完的事情

小刚的解决方案

 小刚想,既然不能修改原函数,那也好办,我再建一个新的函数调用原函数不就完了?

1 def count_time(x):
2     start_time = time.time()
3     x()
4     end_time = time.time()
5     print("time:{}".format(end_time - start_time))
6 
7 
8 count_time(foo)

 

功能是实现了,但是整个公司调用foo函数的人都要跟着要把调用方式改了

小刚被群情激奋的公司员工一顿胖揍

老板也对小刚的方案不满意,小刚被扣5000块工资

小芳被任命接替这份工作

小芳的解决方案

 1 def count_time1(x):
 2     def inner():
 3         start_time = time.time()
 4         x()
 5         end_time = time.time()
 6         print("time:{}".format(end_time - start_time))
 7     return inner
 8 
 9 
10 foo = count_time1(foo)
11 foo()

小芳成功完成任务,老板感觉还可以,奖励了小芳2000元

但是老板认为这个代码还有改进的空间,便让小芳进行改进

python中的装饰器

 1 import time
 2 def count_time(x):
 3     def inner():
 4         start_time = time.time()
 5         x()
 6         end_time = time.time()
 7         print("time:{}".format(end_time - start_time))
 8     return inner
 9 
10 
11 @count_time
12 def foo():
13     time.sleep(1)
14     print("foo.....")
15 
16 
17 foo()

 

 

文章中如果有什么错误,请评论指正,谢谢!

posted @ 2019-08-17 14:56  长江尾  阅读(432)  评论(0编辑  收藏  举报