1、常用实现方式 - 有多少就创建多少,就显示多少

代码:​​(12条消息) QTableWidget常用实现方式-有多少就创建多少,就显示多少-数据集文档类资源-

2、MODEL / VIEW 标准模型实现

代码:​​(12条消息) QTableView-MODELVIEW标准模型实现资源

3、MODEL / VIEW 自定义模型实现

代码:​​(12条消息) QTableView-MODELVIEW自定义模型实现.rar资源

4、DELEGATE + MODEL + VIEW 自定义模型实现

性能分析

Student结构体如下:

struct Student
{
char name[16];
char id[24];
char sex[8];
int age;
char phone[16];
char hobby[24];
char company[16];
};

Student结构体大小为108字节,根据生成的不同数量规模的数据,其程序占用的内存如下:

1、常用实现方式 - 有多少就创建多少,就显示多少

QT 如何用表格显示大数量的数据_数据结构

 根据上述数据,在大规模数据量下,使用QTableWidget展示数据时,每条数据实际占用的内存是数据本身大小的15倍,数据量越大插入越耗时,头部插入耗时远远大于尾部追加插入。

2、MODEL / VIEW 标准模型实现

QT 如何用表格显示大数量的数据_开发语言_02

使用QStandardItemModel与QTableView展示数据,每条数据实际占用内存的大小是数据本身大小的15倍,数据量越大插入越耗时,头部插入耗时远远大于尾部追加插入,其性能表现与QTableWidget相当。

3、MODEL / VIEW 自定义模型实现

使用QAbstractTableModel派生类与QTableView展示数据,每条数据实际占用内存的大小是数据本身大小的1.5倍,数据量越大插入越耗时,由于底层数据结构采用链表实现,头部插入耗时与尾部追加插入耗时相当,但内存空间占用大幅下降。
将底层数据结构为QList,QVector,如下图,前图为QList

QT 如何用表格显示大数量的数据_数据_03

QT 如何用表格显示大数量的数据_数据结构_04

4、DELEGATE + MODEL + VIEW 自定义模型实现

// 继承自 QStyledItemDelegate
// 在 paint 中编写创建 Item 逻辑

// 1.数据未在界面上创建,调用 createItemWidget 进行创建,并在界面上显示

// 2.数据在界面上显示过,但刷新到最下层,现在又拉倒最下层,再次显示的 调用 updateItemWidget setRowHeight进行渲染

// 在大数据的场景中,该函数会根据需要,一点点获取数据,创建显示 item,进行渲染界面,避免一开始渲染所有数据

void LHAbstractItemDelegate::paint(QPainter *painter, const QStyleOptionViewItem &option,
const QModelIndex &index) const
{
Q_UNUSED(painter);
Q_UNUSED(option);

if (m_itemView->indexWidget(index) == nullptr)
{
QWidget *itemWidget = createItemWidget(index);
if (itemWidget != nullptr)
{
m_itemView->setIndexWidget(index, itemWidget);
}
}
else
{
updateItemWidget(index);
setRowHeight(index);
}
}