Вектор C ++, содержащий указатели пользовательских типов - PullRequest
3 голосов
/ 21 сентября 2011

У меня проблема с этим кодом:

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

Это может быть простая проблема, во всяком случае, не для меня:).

Большое спасибо заранее.

1 Ответ

5 голосов
/ 21 сентября 2011

Поскольку ваша функция постоянна, у вас есть только постоянный доступ к указателю this вашего класса.Результаты в постоянном доступе к вашему вектору.Вам нужно получить 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);
    }
}
...