1

我有一个程序可以查询 SQLite 数据库并在表格中显示该数据库中的一些信息。我在程序中已经这样做了几次,并整理了一个更模棱两可的方法来做到这一点,所以我写了一个新的函数,但它总是抛出一个断言:

ASSERT failure in QList<T>::operator[]: "index out of range", file /usr/include/qt/QtCore/qlist.h, line 462

这是我的代码:

void Sync::on_btnLoadTable_clicked()
{
if ( !m_district ) return;

ui->tblTableView->clear();
ui->tblTableView->setRowCount( 0 );
ui->tblTableView->setColumnCount( 0 );

ui->tblTableView->setSortingEnabled( false );

QStringList fields;
QList< QStringList > rows = m_district->getAllOf( ui->cboTables->currentText(), &fields );

int rowCount = rows.size();
if ( rowCount > 0 )
{
    int columns = fields.size();
    ui->tblTableView->setColumnCount( columns );
    for(int c=0; c < columns; c++)
        ui->tblTableView->setHorizontalHeaderItem( c, new QTableWidgetItem(fields[c]) );

    ui->tblTableView->setRowCount( rowCount );
    for(int r=0; r < rowCount; r++)
    {
        int cols = rows[r].size();
        qDebug() << "Fields=" << columns << ", row columns=" << cols;
        qDebug() << "Table is " << ui->tblTableView->columnCount() << "x" << ui->tblTableView->rowCount();
        for(int c=0; c < columns; c++)
        {
            qDebug() << "row column count=" << rows[r].size();
            qDebug() << "row=" << r << ",col=" << c;
            QString data = rows[r][c];
            qDebug() << "text=" << data;
            QTableWidgetItem *item = new QTableWidgetItem( data );
            ui->tblTableView->setItem( r, c, item );
            qDebug() << "inserted [" << r << "," << c << "]";
        }
    }
    qDebug() << "Finished";
}
ui->tblTableView->setSortingEnabled( true );

}

它在 qDebug 中输出以下内容:

Fields= 10 , row columns= 10 
Table is  10 x 6381
row column count= 10 
row= 0 ,col= 0 
text= "137288735238a076b1ed644781a8cdf3f598067b41" 
ASSERT failure in QList<T>::operator[]: "index out of range", file /usr/include/qt/QtCore/qlist.h, line 462

我设置了一系列断点,它似乎在线上中断ui->tblTableView->setItem( r, c, item );,但列和行数似乎暗示行r和列c都是放置项目的有效位置。

任何想法为什么它会给我这个断言?

4

0 回答 0