我有QtTableWidget
7 列和很多行(大约 2000,但会增长到 5000 甚至更多)。
该数据是从数据库中检索的。查询和后处理用了不到 100 毫秒,所以这不是问题。
但是对于 7x2000 个项目,将项目插入表中需要很长时间(大约 30 秒)。
我试图尽可能地优化代码,但我不知道该怎么做了。
另外,我必须注意,当启动应用程序时,会加载具有相同数据集的同一张表,而且速度非常快。所以我相信这是一个渲染问题。
在文档中搜索阻止渲染的内容,我想出了该setUpdatesEnabled
方法,但根本没有帮助。
以下是我用来构建表的代码:
setUpdatesEnabled(false);
blockSignals(true);
bool sort = isSortingEnabled();
setSortingEnabled(false);
// rebuild headers.
buildHeaders(); // take less than 1ms.
// rebuild grid.
int oldRowCount = rowCount();
setRowCount(sml->length()); // take less than 1ms.
ListIterator<StoredMetadata> it(sml); // sml is a list with the data to be displayed.
int row = 0;
while ( it.hasNext() ) {
AudioLife::StoredMetadata *sm = it.next();
if ( row >= oldRowCount ) {
setItem(row, 0, new QTableWidgetItem(sm->artist));
setItem(row, 1, new QTableWidgetItem(sm->album));
setItem(row, 2, new QTableWidgetItem(sm->name));
setItem(row, 3, new QTableWidgetItem(sm->number > 0 ? QString().setNum(sm->number) : ""));
setItem(row, 4, new QTableWidgetItem(sm->year > 0 ? QString().setNum(sm->year) : ""));
setItem(row, 5, new QTableWidgetItem(sm->genre));
// commenting the following line does not improve performance.
verticalHeader()->resizeSection(row, defaultRowHeight());
} else {
item(row, 0)->setText(sm->artist);
item(row, 1)->setText(sm->album);
item(row, 2)->setText(sm->name);
item(row, 3)->setText(sm->number > 0 ? QString().setNum(sm->number) : "");
item(row, 4)->setText(sm->year > 0 ? QString().setNum(sm->year) : "");
item(row, 5)->setText(sm->genre);
}
item(row, 0)->setData(Qt::UserRole, QVariant(sm->id));
row++;
}
setUpdatesEnabled(true);
blockSignals(false);
setSortingEnabled(sort);
有人有任何线索吗?