|
发表于 2023-8-17 11:30:25
|
显示全部楼层
在你提供的代码中,装饰器似乎并没有起到预期的效果。这是因为在装饰器time_master中的内部函数call_func并没有被调用。为了使装饰器生效,你需要在定义call_func后立即调用它。
以下是修正后的代码示例:
- import time
- a = [10, 6, 8, 3, 7, 9, 1, 4, 2, 5]
- def time_master(func):
- def call_func():
- print("开始运行程序...")
- start = time.time()
- func()
- stop = time.time()
- print("结束运行程序...")
- print("共耗时%s" % (stop - start))
-
- return call_func
- @time_master
- def iterSum():
- s = 0
- for i in range(len(a)):
- s = s + a[ i]
- return s
- iterSum()
复制代码
在修正后的代码中,我们将call_func作为内部函数返回,并在time_master装饰器上使用@将其应用于iterSum函数。这样,在调用iterSum函数时,实际上会调用被装饰后的call_func函数。
运行修正后的代码,你会看到输出结果包含了正确的耗时信息。
希望这能解决你的问题!如果还有其他疑问,请随时提问。
如果问题已经解决,请设置最佳答案 |
|