QT 如何用表格显示大数量的数据
精选
原创
©著作权归作者所有:来自51CTO博客作者江南又旧雨的原创作品,请联系作者获取转载授权,否则将追究法律责任
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、常用实现方式 - 有多少就创建多少,就显示多少
根据上述数据,在大规模数据量下,使用QTableWidget展示数据时,每条数据实际占用的内存是数据本身大小的15倍,数据量越大插入越耗时,头部插入耗时远远大于尾部追加插入。
2、MODEL / VIEW 标准模型实现
使用QStandardItemModel与QTableView展示数据,每条数据实际占用内存的大小是数据本身大小的15倍,数据量越大插入越耗时,头部插入耗时远远大于尾部追加插入,其性能表现与QTableWidget相当。
3、MODEL / VIEW 自定义模型实现
使用QAbstractTableModel派生类与QTableView展示数据,每条数据实际占用内存的大小是数据本身大小的1.5倍,数据量越大插入越耗时,由于底层数据结构采用链表实现,头部插入耗时与尾部追加插入耗时相当,但内存空间占用大幅下降。
将底层数据结构为QList,QVector,如下图,前图为QList
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);
}
}