会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132418个问题
Python 全系列/第一阶段:Python入门/编程基本概念 961楼
Python 全系列/第一阶段:Python入门/编程基本概念 964楼
Python 全系列/第六阶段:生产环境部署与协同开发/Linux基本命令 965楼
Python 全系列/第六阶段:生产环境部署与协同开发/Linux系统概述与安装 967楼
人工智能/第五阶段:机器学习-线性回归/多元线性回归 968楼

切片.png

Python 全系列/第一阶段:Python入门/编程基本概念 971楼

索引.png

Python 全系列/第一阶段:Python入门/编程基本概念 972楼

#encoding=utf-8
import time

def cost_time(func):
    def infunc(*args,**kwargs):
        start = time.time()
        result = func(*args,**kwargs)
        end = time.time()
        print(f"耗时:{end-start}")
        return result
    return infunc

class CaheDecorator():
    __cache={} #类属性,用作所有实例的共享缓存
    def __init__ (self ,func):
        self.func = func
    def __call__ (self, *args, **kwargs):
        #如果缓存中有对应的方法名,则直接返回对应的返回值
        if self.func.__name__ in CaheDecorator.__cache:
            return CaheDecorator.__cache[self.func.__name__]
        # 如果缓存中没有对应的方法名,则进行计算,并将结果缓存
        else:
            result = self.func(*args,**kwargs)
            CaheDecorator.__cache[self.func.__name__] = result
            print(self.__cache)
            return result


@cost_time  #func1_long_time = cost_time(func1_long_time)
@CaheDecorator  #func1_long_time=CaheDecorator(func1_long_time)
def func1_long_time():
    """模拟耗时较长,每次执行返回结果都一样的情况"""
    print("start func1")
    time.sleep(3)
    print("end func1")
    return 999

if __name__ == '__main__':
    r1 = func1_long_time()
    r2 = func1_long_time()
    print(r1)
    print(r2)

这段代码的运行顺序是怎么样的?

Python 全系列/第四阶段:函数式编程和核心特性/装饰器深入剖析 974楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637