类的相关问题求解
import time as tclass MyTimer:
def __init__(self):
self.prompt = "未开始计时!"
self.lasted = 0.0
self.default_timer = t.perf_counter()
运行结果:
>>> a = MyTimer()
>>> a.default_timer
11.4577125
>>> a.default_timer
11.4577125
为什么两次调用t.perf_counter()读取的cpu时间相同啊?
我感觉我是没明白
self.default_timer = t.perf_counter()和self.default_timer = t.perf_counter的区别{:5_102:} 本帖最后由 Twilight6 于 2020-8-3 20:06 编辑
带上括号是调用这个函数,而且是这个函数运行后返回的结果
不带括号代表的是表示这个函数体,比如你这就相当于给 perf_counter 函数取了一个 default_timer 的别名,此时调用 default_timer() 相当于调用perf_counter()
因为你是直接调用 perf_counter() 函数后的时间,将这个时间赋值给了 self.default_timer 属性
所以此时 perf_counter() 函数已经将一个固定的结果返回给 self.default_timer 属性
此时你在访问这个属性,返回的永远就是这个属性固定的值
你可以把括号去掉,然后你调用时候带上括号即可:
import time as t
class MyTimer:
def __init__(self):
self.prompt = "未开始计时!"
self.lasted = 0.0
self.default_timer = t.perf_counter
Ps: 你代码中的 t.perf_counter 括号是中文的,需要改成英文
本帖最后由 zltzlt 于 2020-8-3 19:59 编辑
self.default_timer = t.perf_counter() 是直接执行 t.perf_counter() 函数并把该函数的返回值赋值给 self.default_timer 了。
而 self.default_timer = t.perf_counter 是把 t.perf_counter 这个函数本身赋值给 self.default_timer,不会自动执行 t.perf_counter,需要调用时可以 self.default_timer()
页:
[1]