我正在尝试重新定义 Regla 类中的 ==
运算符,并且在每次分配给迭代器时都收到此错误:
no match for 'operator=' in 'it2 = (((const std::list<Condicion, std::allocator<Condicion> >*)(+r)) + 4u)->std::list<_Tp, _Alloc>::begin [with _Tp = Condicion, _Alloc = std::allocator<Condicion>]()'
bool Regla::operator ==(const Regla &r) const{
if(this->condiciones.size()!=r.condiciones.size())
return false;
if(this->acciones.size()!=r.acciones.size())
return false;
list<Condicion>::iterator it,it2;
it2 = r.condiciones.begin();
for(it=condiciones.begin();it!=condiciones.end();it++){
if((*it)!=(*it2)) return false;
it2++;
}
list<Accion>::iterator it3,it4;
it4 = r.acciones.begin();
for(it3=acciones.begin();it3!=acciones.end();it3++){
if((*it3)!=(*it4)) return false;
it4++;
}
return true;
}
怎么样:
list<Condicion>::const_iterator it,it2;
参数 r
是通过 const 引用传递的,隐式this
也是如此,因为运算符本身被标记为 const
,因此不允许两者的成员使用非 const 迭代器。