包含用户定义类型指针的 C++ vector

标签 c++ vector iterator containers qt-creator

我对这段代码有疑问:

struct document_type_content
{
    long long m_ID;
    QString m_type_name;
};

std::vector<QString> document_type::get_fields_by_name(e_doc_type) const
{
    std::vector<QString> tmp;
    std::vector<document_type_content*>::iterator it = m_table_data.begin(),
            it_end = m_table_data.end();

    for ( ; it != it_end; ++it) {
        document_type_content* cnt = *it;
        tmp.push_back(cnt->m_type_name);
    }
}

我在该项目中使用 QtCreator,它给了我以下错误(对于正在初始化迭代器的行):

error: conversion from '__gnu_cxx::__normal_iterator<document_type_content* const*, std::vector<document_type_content*, std::allocator<document_type_content*> > >' to non-scalar type '__gnu_cxx::__normal_iterator<document_type_content**, std::vector<document_type_content*, std::allocator<document_type_content*> > >' requested

这可能是一个简单的问题,无论如何,对我来说不是:)。

非常感谢。

最佳答案

因为您的函数是常量,所以您只能常量访问类的 this 指针。结果是不断地访问您的 vector 。您需要从 vector 中获取一个const_iterator

这应该可以解决问题:

std::vector<QString> document_type::get_fields_by_name(e_doc_type) const
{
    std::vector<QString> tmp;
    std::vector<document_type_content*>::const_iterator it = m_table_data.begin(),
            it_end = m_table_data.end();

    for ( ; it != it_end; ++it) {
        document_type_content* cnt = *it;
        tmp.push_back(cnt->m_type_name);
    }
}

关于包含用户定义类型指针的 C++ vector ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7504396/

相关文章:

c++ - 为什么 C++ 允许您使用已删除的 move 操作来 move 包含对象的类?

.net - 非 .Net C++ 代码的 FxCop(或等同物)

c++ - token 之前的预期初始值设定项

在数组中查找三个数字的算法,使得 a< b < c 和 v[a]<v[c]<v[b]

c++ - 通过迭代器获取 vector 中的索引

c++ - 为什么 std::span 缺少 cbegin 和 cend 方法?

c++ - 从 C++ 中的字符串中删除字符

c++ - 什么会导致 Box2D 突然停止?

c++ - 为什么最后一个被推回 vector 的对象的字段会转移到 vector 的其他对象?

C++ 列表不工作