代码解释:
这段代码实现了一个装饰器函数
time_master,可以用来计算被修饰函数的执行时间。
首先,定义了一个装饰器函数
time_master,它接受一个函数作为参数
func。装饰器函数内部定义了另一个函数
call_func,它负责实际运行被修饰的函数,并计算执行时间。
在
call_func 函数中,首先打印出“开始运行程序......”,然后记录当前时间为
start。接着调用被修饰的函数
func(),即
myfunc()。然后再记录当前时间为
stop。最后打印出“结束程序运行......”和执行时间信息,使用 f-string 格式化输出
(stop-start):.2f 表示显示到小数点后两位。
在主程序中,定义了一个被修饰的函数
myfunc,其中包含了一个
time.sleep(2) 的语句,表示该函数会休眠 2 秒。然后将
myfunc 传递给装饰器函数
time_master,并将返回的函数重新赋值给
myfunc。最后调用
myfunc(),此时实际上执行的是被装饰后的函数
call_func,它会打印出开始和结束运行的信息,并计算出执行时间。
以下是修改后的完整代码:
- import time
- def time_master(func):
- def call_func():
- print("开始运行程序......")
- start = time.time()
- func()
- stop = time.time()
- print("结束程序运行......")
- print(f"一共花费了{(stop-start):.2f}秒。")
- return call_func
- @time_master
- def myfunc():
- time.sleep(2)
- print("hhh")
- myfunc()
复制代码
希望以上解释能够帮助你理解这段代码。如果还有其他问题,请随时提问。
如果回答对你有帮助,请给我一个最佳答案!
