带有QString的模板迭代器

Template iterator with QString

本文关键字:迭代器 QString 带有      更新时间:2023-10-16

我在将vector<'T>的模板迭代器传递给函数QString::fromStdString(const std::string&)

时遇到了问题。

我的功能是,在类型的情况下,T可以将std::string转换为QStringint转换为QString,而不是添加到我的QTableWidget单元格中。

问题是从std::string转换为:

error: no matching function for call to ‘QString::fromStdString(int&)’ QString text = QString::fromStdString(*it);

我不明白为什么迭代对象类型具有int&。我做错了什么?我可以以其他方式转换吗?

template<typename T>
void Dialog::Browse(vector<T> *list, int &counter, QTableWidget *table,     int column)
{
    QTableWidgetItem* item = 0;
    typename vector<T>::iterator it;
    for (it = list->begin(); it != list->end(); ++it){
        QString text;
        if (typeid(*list) == typeid(vector<string>)){
            //QString text = QString::fromUtf8(static_cast<string>(it)->c_str());
            QString text = QString::fromStdString(*it);
        } else if (typeid(*list) == typeid(vector<int>)){
            QString text = QString::number(*it);
        }
        item = new QTableWidgetItem(text);
        item->setFlags(item->flags() & ~Qt::ItemIsEditable);
        table->setItem(counter, column, item);
        counter++;
    }
}

这里的问题是,如果语句不会阻止代码编译。当你做

if (typeid(*list) == typeid(vector<string>)){
    //QString text = QString::fromUtf8(static_cast<string>(it)->c_str());
    QString text = QString::fromStdString(*it);
} else if (typeid(*list) == typeid(vector<int>)){
    QString text = QString::number(*it);
}

无论list是否为vector<string>QString text = QString::fromStdString(*it);行都将被编译。因为当您使用vector<int>调用它时,它试图使用int&编译该代码,然后收到错误。

如果您有C 17,则可以使用If constexpr

if constexpr (typeid(*list) == typeid(vector<string>)){
    //QString text = QString::fromUtf8(static_cast<string>(it)->c_str());
    QString text = QString::fromStdString(*it);
} else if constexpr (typeid(*list) == typeid(vector<int>)){
    QString text = QString::number(*it);
}

现在,只有在条件为真时,代码才会编译。

如果您无法访问C 17,则需要将功能分为过载/专业,以使类型相关代码分开。