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

详解Qt之QCache 高速缓存

文章目录

  • QCache 详解
    • 前言
    • 什么是 QCache?
    • 什么是 LRU 策略?
    • QCache 的构造函数和常用成员函数
      • 构造函数
        • 1. 默认构造函数
        • 2. 指定容量的构造函数
      • 常用成员函数
        • 1. `insert`
        • 2. `object`
        • 3. `contains`
        • 4. `remove`
        • 5. `clear`
        • 6. `setMaxCost`
    • 完整示例代码
    • 总结


QCache 详解

前言

在开发应用程序时,我们常常需要频繁访问某些数据,例如图片、数据库查询结果或计算结果。为了避免重复计算或加载,提高性能,缓存是一种重要的技术。Qt 提供了一个简单易用的缓存工具类——QCache,它实现了一种高效的内存管理策略,能根据使用频率自动清理过时数据。本文将全面介绍 QCache 的用途、构造函数、成员函数以及其采用的 LRU(Least Recently Used,最近最少使用) 策略。


什么是 QCache?

QCache 是 Qt 提供的一个缓存管理类,使用键值对的形式存储数据,并能够根据容量限制管理缓存内容。当缓存达到容量上限时,QCache 会自动移除最近最少使用的数据,为新的数据腾出空间。它是一种高效且易用的缓存工具,适合临时数据的存储与快速访问。


什么是 LRU 策略?

LRU 策略(Least Recently Used,最近最少使用)是一种内存管理算法,主要用于缓存场景。它的核心思想是:

  • 如果缓存满了,就移除最近最少使用的数据。
  • 优先保留最近使用的数据。

简单来说,LRU 策略会将每次使用的数据记录为“最近访问”,而那些长时间未被访问的数据会被优先淘汰。例如:

  1. 假设缓存容量是 3,依次加入 ABC
  2. 如果你访问了 A,然后加入新的数据 D,此时缓存满了,会移除最近最少使用的 B
  3. 最终缓存中存储的是 ACD

QCache 的构造函数和常用成员函数

构造函数

1. 默认构造函数
  • 函数原型

    QCache();
    
  • 作用
    创建一个默认的空缓存,没有设置最大容量。

  • 示例代码

    QCache<QString, QString> cache;
    
2. 指定容量的构造函数
  • 函数原型

    QCache(int maxCost);
    
  • 作用
    创建一个容量为 maxCost 的缓存。

  • 参数

    • maxCost:缓存的最大容量。
  • 示例代码

    QCache<QString, QString> cache(10); // 最多存储 10 项数据
    

常用成员函数

1. insert
  • 函数原型

    bool insert(const Key &key, T *object, int cost = 1);
    
  • 作用
    将一个数据项插入缓存。如果缓存容量不足,会自动移除最久未使用的数据。

  • 参数

    • key:数据的键。
    • object:数据的值(必须是指针)。
    • cost:数据的代价(默认值为 1,表示占用 1 单位的缓存容量)。
  • 返回值
    返回布尔值,表示插入是否成功。

  • 示例代码

    QCache<QString, QString> cache(3);
    cache.insert("key1", new QString("value1"));
    cache.insert("key2", new QString("value2"));
    

2. object
  • 函数原型

    T *object(const Key &key) const;
    
  • 作用
    根据键获取对应的值。

  • 参数

    • key:需要查找的键。
  • 返回值
    返回指向缓存中对应值的指针。如果键不存在,则返回 nullptr

  • 示例代码

    QString *value = cache.object("key1");
    if (value) {
        qDebug() << "Value:" << *value;
    }
    

3. contains
  • 函数原型

    bool contains(const Key &key) const;
    
  • 作用
    检查缓存中是否存在指定的键。

  • 参数

    • key:需要检查的键。
  • 返回值
    如果存在则返回 true,否则返回 false

  • 示例代码

    if (cache.contains("key1")) {
        qDebug() << "Cache contains key1";
    }
    

4. remove
  • 函数原型

    bool remove(const Key &key);
    
  • 作用
    移除指定键的数据项。

  • 参数

    • key:需要移除的键。
  • 返回值
    如果成功移除,则返回 true,否则返回 false

  • 示例代码

    cache.remove("key1");
    

5. clear
  • 函数原型

    void clear();
    
  • 作用
    清空缓存中的所有数据。

  • 示例代码

    cache.clear();
    

6. setMaxCost
  • 函数原型

    void setMaxCost(int maxCost);
    
  • 作用
    动态设置缓存的最大容量。

  • 参数

    • maxCost:新的最大容量。
  • 示例代码

    cache.setMaxCost(5); // 设置最大容量为 5
    

完整示例代码

以下是一个完整的示例代码,演示如何使用 QCache 和其常用功能:

#include <QCache>
#include <QDebug>

int main() {
    // 创建一个最多存储 3 项的缓存
    QCache<QString, QString> cache(3);

    // 插入数据
    cache.insert("key1", new QString("value1"));
    cache.insert("key2", new QString("value2"));
    cache.insert("key3", new QString("value3"));

    // 访问数据
    QString *value = cache.object("key1");
    if (value) {
        qDebug() << "Value of key1:" << *value;
    }

    // 插入新数据,触发 LRU
    cache.insert("key4", new QString("value4")); // "key2" 会被移除

    // 检查是否移除
    if (!cache.contains("key2")) {
        qDebug() << "key2 has been removed due to LRU.";
    }

    // 清空缓存
    cache.clear();

    return 0;
}

总结

QCache 是一个轻量级的缓存工具,适用于临时数据的快速存取。通过采用 LRU 策略,它能在缓存满时自动移除最近最少使用的数据,减少手动管理内存的复杂性。借助其简单直观的 API 和高效的内存管理机制,QCache 成为 Qt 开发中处理缓存的一个强有力工具。如果你的应用需要频繁访问一些临时数据,那么 QCache 是一个值得优先选择的解决方案。


http://www.kler.cn/a/412791.html

相关文章:

  • 【GIT】TortoiseGit的拉取(Pull) 和 获取(Fetch)
  • Microsoft Excel如何插入多行
  • Ajax、Fetch、Axios、XMLHttpRequest 的关系与区别
  • 阿里发布 EchoMimicV2 :从数字脸扩展到数字人 可以通过图片+音频生成半身动画视频
  • 【leetcode100】轮转数组
  • 【carla生成车辆时遇到的问题】carla显示的坐标和carlaworld中提取的坐标y值相反
  • 深度学习基础02_损失函数BP算法(上)
  • 分布式项目使用Redis实现数据库对象自增主键ID
  • 音视频入门基础:MPEG2-TS专题(8)——TS Header中的适配域
  • 了解UIUX设计
  • Linux 服务器使用指南:诞生与演进以及版本(一)
  • 【软考速通笔记】系统架构设计师⑤——软件工程基础知识
  • 转录组数据挖掘(生物技能树)(第11节)下游分析
  • 【设计模式】1. 构建器模式(Builder Pattern)是一种创建型设计模式
  • 林业产品推荐系统:Spring Boot设计模式
  • 【MySQL系列】使用正则表达式确保`card_secret`字段格式正确
  • 【python】面试宝典(五)
  • 如何将低危的 SSRF 盲注升级为严重漏洞(AWS、S3)
  • SpringBoot开发——详细讲解 Spring Boot 项目中的 POM 配置
  • 利用Prompt工程为LLM提升推理能力
  • 自媒体图文视频自动生成软件|03| 页面和结构介绍
  • <<WTF-Solidity>>学习笔记(part 5-8)
  • 模糊逻辑学习 | 模糊推理 | 模糊逻辑控制
  • 通信综合—8.通信网络安全
  • OpenCV相机标定与3D重建(7)鱼眼镜头立体校正的函数stereoRectify()的使用
  • 设计模式:10、外观模式