0

当我编写以下内容时发生编译错误:

const_iterator it = cp.begin();

const_iterator是我自己的课const iterator
cp是一个类的对象ConjuntoPreguntas(见下文)。
错误是:

mainprueba.cpp:30:6: error: no match for ‘operator=’ (operand types are ‘ConjuntoPreguntas::const_iterator’ and ‘ConjuntoPreguntas::iterator’)
  cit = CP.begin();
      ^
mainprueba.cpp:30:6: note: candidate is:
In file included from mainprueba.cpp:2:0:
conjuntopreguntas.h:258:21: note: ConjuntoPreguntas::const_iterator& ConjuntoPreguntas::const_iterator::operator=(const ConjuntoPreguntas::const_iterator&)
     const_iterator& operator=(const const_iterator& cit){
                     ^
conjuntopreguntas.h:258:21: note:   no known conversion for argument 1 from ‘ConjuntoPreguntas::iterator’ to ‘const ConjuntoPreguntas::const_iterator&’

编码:

class ConjuntoPreguntas{
private:
    map<int,Pregunta> preguntas;

public:     
    class const_iterator;

    class iterator{
    private:
          map<int,Pregunta>::iterator it;

    public:
          iterator & operator++(){
           ++it;
          }

          iterator & operator--(){
           --it;
          }

          pair<const int,Pregunta> &operator *(){
           return *it;
          }

          bool operator ==(const iterator &i){
           return i.it==it;
          }   

          bool operator !=(const iterator &i){
           return i.it!=it;
          }

          friend class ConjuntoPreguntas;
          friend class const_iterator;
    };


    class const_iterator{
    private:
          map<int,Pregunta>::iterator it;
    public:
          const_iterator(){ 
          }

          const_iterator & operator++(){
           ++it;
          }

          const_iterator & operator--(){
           --it;
          }

          pair<const int,Pregunta> &operator *(){
           return *it;
          }

          bool operator ==(const const_iterator &i){
           return i.it==it;
          }   

          bool operator !=(const const_iterator &i){
           return i.it!=it;
          }

          const_iterator& operator=(const const_iterator& cit){
          }

          friend class ConjuntoPreguntas;

    };

    iterator begin(){
        iterator i;
        i.it=preguntas.begin();
        return i;
    }   

    iterator end(){
        iterator i;
        i.it=preguntas.end();
        return i;
    }
/* other code, irrelevant to the problem */                             
};   

如果有人可以帮助我,我将不胜感激。

4

2 回答 2

1

您最直接的问题是因为您没有以下const版本begin

   const_iterator begin() const
   {
        const_iterator i;
        i.it = preguntas.begin();
        return i;
    }

但是你的const_iterator班级也使用了地图的迭代器,这将导致另一个问题。

如果您正在编写一个看起来像容器的类,那么除了编写 const 正确的迭代器和 const_iterator 类并提供 const 正确的成员之外别无他法。

但是,如果您不编写容器,则可能不想这样做。最好的情况是为类提供与容器无关的接口,例如,您提供有意义的名称而不是直接容器访问。或者通过映射提供仅 const 访问const_iterator(不要编写自己的迭代器类)。

于 2015-12-07T22:02:50.767 回答
0

如果您想将 std 容器完全封装在您的类中(令人生畏且通常是不必要的任务),您需要确保您还定义了所有转换。特别是,标准容器迭代器有一个构造函数,它从迭代器创建 const_iterator (但不是相反!)。您也必须自己创建它。

但是,更好的设计选择是简单地公开成员map变量。

于 2015-12-07T21:45:37.187 回答