QT-【常用容器类】-QList类 QLinkedList类

news2024/12/29 2:46:45

QListQLinkedList 是 Qt 框架中提供的两个重要容器类,用于存储和管理一组数据。它们各自具有不同的特点和优缺点,适用于不同的场景。


1. QList 类概述

QList 是一个动态数组类,提供了对元素的快速随机访问。它的实现类似于 C++ 标准库中的 std::vector。通过 QList,开发者可以方便地管理一组相同类型的元素。

1.1 QList 的特性

  • 动态数组QList 可以自动扩展以容纳更多元素,适合用于大小不确定的列表。
  • 随机访问:支持快速的随机访问操作,时间复杂度为 O(1),适合频繁访问的场景。
  • 内存管理QList 使用引用计数来管理元素的内存,这意味着在列表中存储的对象将自动释放。
  • 支持复制QList 支持值语义和引用语义,可以安全地复制和传递。

1.2 QList 的基本用法

以下是 QList 的基本用法示例,包括创建、插入、删除和遍历元素。

cpp

#include <QList>
#include <QString>
#include <QDebug>

int main() {
    // 创建 QList
    QList<QString> list;

    // 添加元素
    list.append("Hello"); // 在末尾添加 "Hello"
    list.append("World"); // 在末尾添加 "World"

    // 插入元素
    list.insert(1, "Qt"); // 在索引 1 处插入 "Qt"

    // 访问元素
    qDebug() << list[0]; // 输出 "Hello"
    qDebug() << list.at(1); // 输出 "Qt"

    // 遍历元素
    for (const QString& str : list) {
        qDebug() << str; // 输出每个元素
    }

    // 删除元素
    list.removeAt(1); // 删除索引 1 的元素

    // 清空列表
    list.clear(); // 清空列表

    return 0;
}

1.3 QList 的常用方法

  • append(const T &value):在列表末尾添加一个元素。
  • insert(int i, const T &value):在指定索引处插入一个元素。
  • removeAt(int i):删除指定索引处的元素。
  • clear():清空列表,移除所有元素。
  • size():返回列表中的元素数量。
  • isEmpty():检查列表是否为空,返回布尔值。
  • indexOf(const T &value):查找元素并返回其索引,如果不存在则返回 -1。
  • contains(const T &value):检查列表是否包含某个元素。

1.4 QList 的性能分析

  • 插入和删除:在列表末尾插入或删除元素的时间复杂度是 O(1),在中间插入或删除的时间复杂度为 O(n),因为需要移动后续的元素。
  • 访问:访问元素的时间复杂度为 O(1),适合需要频繁随机访问的场景。
  • 内存使用QList 在内存使用上相对高效,但在进行大量插入和删除操作时,可能会导致频繁的内存重新分配。

2. QLinkedList 类概述

QLinkedList 是一个双向链表类,允许在列表的两端和中间位置进行快速插入和删除操作。其设计适合于需要频繁修改元素的场景。

2.1 QLinkedList 的特性

  • 双向链表:每个节点包含指向前一个和后一个节点的指针,允许双向遍历。
  • 插入和删除性能:在链表中间插入和删除的操作时间复杂度为 O(1),适合频繁修改的场景。
  • 不支持随机访问:访问列表元素的时间复杂度为 O(n),不适合需要频繁随机访问的场景。
  • 内存管理:同样使用引用计数来管理元素的内存。

2.2 QLinkedList 的基本用法

以下是 QLinkedList 的基本用法示例,包括创建、插入、删除和遍历元素。

cpp

#include <QLinkedList>
#include <QString>
#include <QDebug>

int main() {
    // 创建 QLinkedList
    QLinkedList<QString> linkedList;

    // 添加元素
    linkedList.append("Hello"); // 添加 "Hello"
    linkedList.append("World"); // 添加 "World"

    // 在头部插入元素
    linkedList.prepend("Qt"); // 在开头添加 "Qt"

    // 访问元素
    qDebug() << linkedList.first(); // 输出 "Qt"
    qDebug() << linkedList.last(); // 输出 "World"

    // 遍历元素
    for (const QString& str : linkedList) {
        qDebug() << str; // 输出每个元素
    }

    // 删除元素
    linkedList.removeFirst(); // 删除第一个元素
    linkedList.removeLast(); // 删除最后一个元素

    // 清空列表
    linkedList.clear(); // 清空链表

    return 0;
}

2.3 QLinkedList 的常用方法

  • append(const T &value):在链表末尾添加一个元素。
  • prepend(const T &value):在链表开头添加一个元素。
  • removeFirst():删除链表的第一个元素。
  • removeLast():删除链表的最后一个元素。
  • first():返回链表的第一个元素。
  • last():返回链表的最后一个元素。
  • size():返回链表中的元素数量。
  • isEmpty():检查链表是否为空,返回布尔值。

2.4 QLinkedList 的性能分析

  • 插入和删除:在链表的头部或尾部插入和删除的时间复杂度为 O(1),在链表中间插入或删除的时间复杂度也是 O(1),前提是你已经获得了该位置的迭代器。
  • 访问:访问元素的时间复杂度为 O(n),因此不适合频繁随机访问的场景。
  • 内存使用:由于每个节点都需要存储两个指针,QLinkedList 在内存占用上可能比 QList 更高,但在进行大量插入和删除操作时,QLinkedList 更加高效。

3. QList 和 QLinkedList 的比较

3.1 使用场景

  • QList

    • 适合需要频繁随机访问的场景,如查找、排序等操作。
    • 数据量不大且插入和删除操作不频繁时,QList 是一个理想选择。
  • QLinkedList

    • 适合需要频繁插入和删除操作的场景,特别是在中间位置。
    • 不需要随机访问时,可以使用 QLinkedList 来节省内存和提高性能。

3.2 优缺点总结

特性QListQLinkedList
存储方式动态数组双向链表
随机访问快速(O(1))慢(O(n))
插入/删除性能尾部 O(1),中间 O(n)头尾 O(1),中间 O(1)(需迭代器)
内存使用相对高效较高(每个节点需额外存储指针)
适用场景随机访问频繁,修改少插入删除频繁,随机访问少

4. 实际使用中的注意事项

在使用 QListQLinkedList 时,有一些注意事项可以帮助你更有效地利用这些容器:

  1. 选择合适的容器:根据具体需求选择 QListQLinkedList。如果频繁访问元素,选择 QList;如果频繁插入和删除元素,选择 QLinkedList

  2. 内存管理:虽然 Qt 的容器类会自动管理内存,但在使用自定义对象时,确保这些对象的析构函数正确实现,以避免内存泄漏。

  3. 避免不必要的复制:在需要传递 QListQLinkedList 给函数时,尽量使用引用(const QList<T>&const QLinkedList<T>&)来避免不必要的复制开销。

  4. 迭代器使用:在 QLinkedList 中频繁插入和删除时,使用迭代器可以提高效率。获取迭代器后,可以在 O(1) 的时间复杂度内进行插入和删除。

  5. 性能分析:在性能敏感的应用程序中,建议进行基准测试,以确定在特定情况下哪种容器表现更好。

5. 结论

QListQLinkedList 是 Qt 框架中非常重要的容器类,各自具有不同的优缺点和适用场景。QList 适合于需要频繁随机访问的情况,而 QLinkedList 更适合于频繁插入和删除的场景。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2266671.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

UE5 渲染管线 学习笔记

兰伯特 SSS为散射的意思 带Bias的可以根据距离自动切换mip的卷积值 而带Level的值mipmaps的定值 #define A8_SAMPLE_MASK .a 这样应该就很好理解了 这个只采样a通道 带Level的参考上面的 朝左上和右下进行模糊 带Bias参考上面 随机数 4D 3D 2D 1D HLSL内置UV HLSL内置鼠标坐…

【Kubernetes 指南】基础入门——Kubernetes 基本概念(二)

目录 二、Pod 1、Pod 简介 2、Pod 图示 3、nginx 容器 二、Pod 1、Pod 简介 - Kubernetes 使用 Pod 来管理容器&#xff0c;每个 Pod 可以包含一个或多个紧密关联的容器。 - Pod 是一组紧密关联的容器集合&#xff0c;它们共享 PID、IPC、Network 和 UTS namespace&#…

基于高德地图js api实现掩膜效果 中间矢量 周围卫星图

<!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>管网服务</title><style>html,body,#ma…

【EI会议征稿】人工智能与遥感应用国际会议 (AIRSA 2025)

第一届人工智能与遥感应用国际学术会议&#xff08;AIRSA 2025&#xff09;将于2025年3月14-17日在中国长沙召开。会议聚焦人工智能与遥感技术应用&#xff0c;旨在为参会专家、学者和相关研究人员提供一个共享科研成果&#xff0c;拓宽研究思路&#xff0c;探索前沿技术&#…

Java圣诞树

目录 写在前面 技术需求 程序设计 代码分析 一、代码结构与主要功能概述 二、代码功能分解与分析 1. 类与常量定义 2. 绘制树的主逻辑 3. 彩色球的绘制 4. 动态效果的实现 5. 窗口初始化 三、关键特性与优点 四、总结 写在后面 写在前面 Java语言绘制精美圣诞树…

java web项目软件自动生成使用初体验-帅帅软件生成平台ASoft

软件默认 登陆账号 admin 密码 123456 一、软件使用简介说 AI软件自动生成越来越成熟&#xff0c;但AI生成的软件代码只是片段化的&#xff0c;不成体系。有没有一款可以10-30分钟自动生成JAVA WEB休系的软件&#xff1f;我也找了好久&#xff0c;终于找到了&#xff0c;开发…

闲谭Scala(2)--安装与环境配置

1. 概述 Java开发环境安装&#xff0c;需要两步&#xff0c;第一安装JDK&#xff0c;第二配置环境变量。 Scala的话&#xff0c;也是两步&#xff0c;第一安装Scale环境&#xff0c;第二配置环境变量。 需要注意的是&#xff0c;配置环境变量&#xff0c;主要是想让windows操…

NodeRed使用心得,实现增删改查等

使用场景介绍 在VUE中使用nodeRed实现对节点的 增删改查等功能&#xff0c;且储存成功之后下点击时启动对应流程 安装与配置 1.安装NodeRed npm install -g --unsafe-perm node-red 安装完成后&#xff0c;你可以通过运行以下命令来启动Node-RED node-red-start2. 配置文件 N…

升级鸿蒙Next,小记

写在前面 这个小记是想记录一下Next系统不断完善的过程&#xff0c;给想升级还没升级的同志们一些提醒。虽然这个系统还有这样那样的一些问题&#xff0c;但是我觉得升级之后很完美 续航时间明显变长了&#xff0c;充电&#xff0c;玩游戏以前会发热&#xff0c;现在完全不会…

Android Studio | 连接手机设备后,启动App时出现:Waiting For DebuggerApplication (App名)...

在这种情况下&#xff0c;打开目录文件&#xff0c;出现 Is:/storage/emulated/: Permission denied 问题分析&#xff1a; 以上两种情况表明应用程序试图访问Android设备的存储空间中的/storage/emulated/目录&#xff0c;但是没有足够的权限去执行这个操作。 解决办法&…

如何卸载和升级 Angular-CLI ?

Angular-CLI 是开发人员使用 Angular 的必备工具。然而&#xff0c;随着频繁的更新和新版本的出现&#xff0c;了解如何有效地卸载和升级 Angular-CLI 对开发人员来说至关重要。本指南提供了一个全面的、循序渐进的方法来帮助您顺利过渡到最新版本。 必备条件 确保您的系统上…

jangow靶机

打开靶机&#xff0c;打开kali&#xff0c;有的人会发现扫不到靶机的ip 在网上搜索了半天&#xff0c;发现是靶机的网卡配置有问题 重启靶机&#xff0c;选第二个 进去后再选第二个&#xff0c;按e 找到ro这一行 把ro后面这一行的内容都替换成ro rw signin init/bin/bash ctr…

[c++进阶(三)]单例模式及特殊类的设计

1.前言 在实际场景中,总会遇见一些特殊情况,比如设计一个类,只能在堆上开辟空间, 或者是设计一个类只能实例化一个对象。那么我们应该如何编写代码呢&#xff1f;本篇将会详细的介绍 本章重点&#xff1a; 本篇文章着重讲解如何设计一些特殊 的类,包括不能被拷贝,只能在栈/堆上…

CSharp: Oracle Stored Procedure query table

存储过程查询postgreSQL,Oracle 和sql server,Mysql 有区别。程序调用也是有区别。 oracle sql script: CREATE OR REPLACE PROCEDURE procSelectSchool(paramSchoolId IN char,p_cursor OUT SYS_REFCURSOR ) AS BEGINOPEN p_cursor FORSELECT *FROM SchoolWHERE SchoolId p…

macos 隐藏、加密磁盘、文件

磁盘加密 打开磁盘工具 点击添加 设置加密参数 设置密码 查看文件 不用的时候右键卸载即可使用的时候装载磁盘&#xff0c;并输入密码即可 修改密码 解密 加密&#xff0c;输入密码即可 禁止开机自动挂载此加密磁盘 如果不禁止自动挂载磁盘&#xff0c;开机后会弹出输入…

cesium入门学习一

1.学习目的 作为网页显示&#xff0c;我只要实现了cesium网页显示&#xff0c;就可以到时候通过qt的webview显示html界面&#xff0c;来显示地图&#xff0c;js对于学过c的人而言&#xff0c;没啥难度&#xff0c;不过是换一种语法&#xff0c;而且cesium的教程相对于osgeart…

dify的ChatFlow自定义上传图片并通过HTTP请求到SpringBoot后端

前情提要 交互场景&#xff1a;dify的ChatFlow上传文件(本示例是单张图片)&#xff0c;通过HTTP请求至SpringBoot后端dify版本&#xff1a;0.13.2python版本&#xff1a;3.12.7 1. 自定义上传变量 在【开始】节点自定义变量单文件上传变量file 2. 下接HTTP请求节点 BODY要…

Flutter DragTarget拖拽控件详解

文章目录 1. DragTarget 控件的构造函数主要参数&#xff1a; 2. DragTarget 的工作原理3. 常见用法示例 1&#xff1a;实现一个简单的拖拽目标解释&#xff1a;示例 2&#xff1a;与 Draggable 结合使用解释&#xff1a; 4. DragTarget 的回调详解5. 总结 DragTarget 是 Flutt…

深度学习blog-Transformer-注意力机制和编码器解码器

注意力机制&#xff1a;当我们看一个图像或者听一段音频时&#xff0c;会根据自己的需求&#xff0c;集中注意力在关键元素上&#xff0c;以获取相关信息。 同样地&#xff0c;注意力机制中的模型也会根据输入的不同部分&#xff0c;给它们不同的权重&#xff0c;并集中注意力在…

改进爬山算法之一:随机化爬山法(Stochastic Hill Climbing,SHC)

随机化爬山法(Stochastic Hill Climbing),也被称为随机爬山法,是一种基于搜索算法的优化方法,是爬山算法的一个变种,它通过引入随机性来减少算法陷入局部最优解的风险,并增加搜索解空间的能力。这种方法特别适合于解决那些具有多个局部最优解的优化问题。 一、算法思想 …