当前位置: 首页 > wzjs >正文

免费的网络软件重庆网页优化seo公司

免费的网络软件,重庆网页优化seo公司,四川省建设安全管理协会网站,wordpress获取用户注册时间functools.lru_cache 是 Python 标准库 functools 模块中的一个装饰器,用于实现简单的缓存机制。它通过缓存函数的返回值来提高函数的执行效率,特别是对于那些被多次调用且参数相同的函数。 LRU 缓存机制 LRU 代表 Least Recently Used,即最…

functools.lru_cache 是 Python 标准库 functools 模块中的一个装饰器,用于实现简单的缓存机制。它通过缓存函数的返回值来提高函数的执行效率,特别是对于那些被多次调用且参数相同的函数。

LRU 缓存机制

  • LRU 代表 Least Recently Used,即最近最少使用。

  • LRU 缓存机制会保存最近使用的缓存项,并在缓存满时丢弃最久未使用的项。

lru_cache 装饰器的参数

  • maxsize:指定缓存中可以存储的最大键值对数量,类型:intNone

    • 如果 maxsize=None,则缓存大小无限制。

    • 如果指定了 maxsize,则缓存会限制为该大小。当缓存满时,最久未使用的缓存项会被丢弃(LRU 策略)。

  • 默认值 128 表示缓存可以存储最多 128 个键值对。

  • 每个键值对包括:

    • :函数的参数(包括位置参数和关键字参数)。

    • :函数的返回值。

  • typed:

    • 类型:bool

    • 默认值:False

    • 描述:如果设置为 True,则会区分不同类型的参数。例如,f(3)f(3.0) 会被视为不同的调用。

使用示例

示例 1:缓存斐波那契数列
import functools
import time@functools.lru_cache(maxsize=None)
def fibonacci(n):if n < 2:return nreturn fibonacci(n - 1) + fibonacci(n - 2)# 记录开始时间
start_time = time.time()print(fibonacci(30))  # 计算斐波那契数列的第 30 项# 记录结束时间
end_time = time.time()# 计算运行时间
run_time = end_time - start_time
print(f"加了@lru_cache 装饰器的fibonacci 运行时间: {run_time} 秒")def fibonacci(n):if n < 2:return nreturn fibonacci(n - 1) + fibonacci(n - 2)print(fibonacci(30))  # 计算斐波那契数列的第 30 项# 记录开始时间
start_time = time.time()print(fibonacci(30))  # 计算斐波那契数列的第 30 项# 记录结束时间
end_time = time.time()# 计算运行时间
run_time = end_time - start_time
print(f"没有 @lru_cache 装饰器的fibonacci 运行时间: {run_time} 秒")

解释

  • 没有缓存时,计算斐波那契数列的第 30 项会非常慢,因为有大量的重复计算。

  • 使用 lru_cache 后,函数的返回值被缓存,重复调用时直接从缓存中获取结果,大大提高了效率。

示例 2:缓存单位四元数

Python复制

import functools
import torch@functools.lru_cache(maxsize=None)
def identity_quats(batch_dims, dtype=None, device=None, requires_grad=True):quat = torch.zeros((*batch_dims, 4), dtype=dtype, device=device, requires_grad=requires_grad)with torch.no_grad():quat[..., 0] = 1return quat# 调用函数
quats = identity_quats((2, 3), dtype=torch.float32, device=torch.device('cpu'), requires_grad=True)
print(quats)

输出

plaintext复制

tensor([[[1., 0., 0., 0.],[1., 0., 0., 0.],[1., 0., 0., 0.]],[[1., 0., 0., 0.],[1., 0., 0., 0.],[1., 0., 0., 0.]]], grad_fn=<CopySlices>)

解释

  • 第一次调用 identity_quats 时,函数会计算并缓存结果。

  • 后续调用时,如果参数相同,直接从缓存中返回结果,避免重复计算。

缓存内容和生命周期

缓存的内容
  • 最终返回值lru_cache 只缓存函数的最终返回值。它不会保存函数执行过程中的中间状态或中间值。

  • 键值对:缓存是以键值对的形式存储的,其中键是函数的参数(包括位置参数和关键字参数),值是函数的返回值。

缓存的生命周期
  • 内存中保存:缓存的值会一直保留在内存中,直到程序退出,或者缓存被手动清除。

  • 手动清除缓存:可以使用 cache_clear 方法手动清除缓存。例如:

    fibonacci.cache_clear()

    这将清除 fibonacci 函数的所有缓存值。

总结

functools.lru_cache 是一个非常有用的装饰器,用于缓存函数的返回值,从而提高函数的执行效率。它特别适用于那些被多次调用且参数相同的函数。通过合理使用 lru_cache,可以显著提高程序的性能。

http://www.dtcms.com/wzjs/289453.html

相关文章:

  • 本机可以做网站的服务器百度快照推广一年要多少钱
  • 这么制作自己的网站免费推广公司
  • 网站服务公司业务范围包括网推是什么
  • 网店美工毕业设计百度推广优化方案
  • 自己有域名如何做网站廊坊seo外包公司费用
  • 代驾app软件开发公司曹操论坛seo
  • 网站建设怎么进后台平台推广员是做什么的
  • 网站建设 网站内容 采集福建seo排名培训
  • 软件开发费用计算方法seo推广优化外包价格
  • 网站建设与规划湖南seo网站多少钱
  • 网站管理系统怎么用seo排名优化推广报价
  • 建个网站要花多少钱加快百度收录的方法
  • 河南软件开发公司有哪些seo用什么工具
  • 西安网站建设开发公司网络营销活动策划
  • 哈尔滨市做网站整合营销策划
  • 购买保险的网站域名注册网
  • 庆阳手机网站设计企业网站的功能
  • 做网站空间放哪些文件夹网络广告文案
  • 网站底部友情链接代码统计工具
  • 做网站用上面软件写代码比较好什么是网络整合营销
  • 高端网站建设收费为何比较贵模板网站建设开发
  • 英文网站推广工作9个广州seo推广神技
  • 汕头网站搜索优化百度排行榜前十名
  • 免费网站建设 百度一下收录查询站长工具
  • 昌平企业网站建设济南seo网站关键词排名
  • 网站建设 客户要退款无代码免费web开发平台
  • 网站版权 技术支持百度网址大全电脑版旧版本
  • 苏州网站建设书生商友seo推广岗位职责
  • 公司做网站的优势网站系统开发
  • 跨境电商网站怎么做seo搜索引擎优化步骤