鱼C论坛

 找回密码
 立即注册
查看: 998|回复: 6

[已解决]关于第044讲:魔法方法:简单定制最后一题的疑问

[复制链接]
发表于 2022-3-30 15:52:10 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
各位老师这段代码
import time as t

class MyTimer:
    def __init__(self, func, number=1000000):
        self.prompt = "未开始计时!"
        self.lasted = 0.0
        self.default_timer = t.perf_counter
        self.func = func                             这个func是一个参数需要在实列时传入这个参数对吗。
        self.number = number
   
    def __str__(self):
        return self.prompt

    __repr__ = __str__

    def __add__(self, other):
        result = self.lasted + other.lasted
        prompt = "总共运行了 %0.2f 秒" % result
        return prompt

    # 内部方法,计算运行时间
    def timing(self):
        self.begin = self.default_timer()
        for i in range(self.number):
            self.func()                                                    这个地方是调用这个func函数。我看这段代码里没有设置func的函数方法这个地方我不是很明白。哪位老师能帮我看看谢谢了
        self.end = self.default_timer()
        self.lasted = self.end - self.begin
        self.prompt = "总共运行了 %0.2f 秒" % self.lasted
        
    # 设置计时器(time.perf_counter() 或 time.process_time())
    def set_timer(self, timer):
        if timer == 'process_time':
            self.default_timer = t.process_time
        elif timer == 'perf_counter':
            self.default_timer = t.perf_counter
        else:
            print("输入无效,请输入 perf_counter 或 process_time")
最佳答案
2022-3-30 19:39:21
redaiconglin 发表于 2022-3-30 16:03
那我传入一个什么函数呢。能举个列子吗老师。谢谢你了

你可以自己写一个函数
带循环的比较好,运行时间长点
def dmq():  # 函数
    for i in range(100):
        continue
创建实例化对象时
mt1 = MyTimer(dmq)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-3-30 15:57:32 | 显示全部楼层
在实例化时将函数传进去之后,
里面的变量在这些函数中是可以跨作用域使用的,相当于 t.func = 你的函数,这样在内部调用并不需要申明
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-3-30 16:03:38 | 显示全部楼层
python爱好者. 发表于 2022-3-30 15:57
在实例化时将函数传进去之后,
里面的变量在这些函数中是可以跨作用域使用的,相当于 t.func = 你的函数, ...

那我传入一个什么函数呢。能举个列子吗老师。谢谢你了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-3-30 16:09:02 | 显示全部楼层
redaiconglin 发表于 2022-3-30 16:03
那我传入一个什么函数呢。能举个列子吗老师。谢谢你了

不明白这段代码里面这个func的作用是什么
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-3-30 19:39:21 | 显示全部楼层    本楼为最佳答案   
redaiconglin 发表于 2022-3-30 16:03
那我传入一个什么函数呢。能举个列子吗老师。谢谢你了

你可以自己写一个函数
带循环的比较好,运行时间长点
def dmq():  # 函数
    for i in range(100):
        continue
创建实例化对象时
mt1 = MyTimer(dmq)

评分

参与人数 1荣誉 +5 鱼币 +5 贡献 +3 收起 理由
redaiconglin + 5 + 5 + 3 感谢楼主无私奉献!

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-3-30 19:41:54 | 显示全部楼层
这个代码就是用来统计一个函数的运行时间
func用来运行,然后得到它运行时间的函数
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2022-3-30 20:46:46 | 显示全部楼层
大马强 发表于 2022-3-30 19:41
这个代码就是用来统计一个函数的运行时间
func用来运行,然后得到它运行时间的函数

明白了谢谢老师
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-11 21:05

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表