lingedu 发表于 2020-8-3 19:57:06

类的相关问题求解

import time as t
class 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 19:58:04

本帖最后由 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:58:25

本帖最后由 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]
查看完整版本: 类的相关问题求解