Estoy escribiendo una envoltura delgada plantilla para iteradores, y chocó contra un obstáculo a su paso por el operador de la estructura de eliminar la referencia, sobre todo porque los punteros no tienen uno:Estructura operador eliminar la referencia (del operador>)
#include <vector>
struct mystruct {
int member;
};
template<class iterator>
struct wrap {
typedef typename std::iterator_traits<iterator>::pointer pointer;
iterator internal;
pointer operator->() {return internal.operator->();} //MARK1
};
int main() {
wrap<std::vector<mystruct>::iterator> a;
a->member;
wrap<mystruct*> b;
b->member;
return 0;
}
prog.cpp: In member function ‘typename std::iterator_traits<_Iter>::pointer wrap<iterator>::operator->() [with iterator = mystruct*]’:
prog.cpp:18: instantiated from here
prog.cpp:11: error: request for member ‘operator->’ in ‘((wrap<mystruct*>*)this)->wrap<mystruct*>::internal’, which is of non-class type ‘mystruct*’
Esto siguiente método funciona, pero creo que no se garantiza que funcione. A saber, si un iterador tiene un tipo extraño pointer
que no es lo mismo que un puntero a value_type
.
pointer operator->() {return &*internal;} //MARK3
¿Qué versión de C++ tiene una estructura de operador * * eliminar la referencia? –
¿Por qué 'char *'? ¿No habría algún tipo de 'Iterator :: value_type' en alguna parte? –
@ThomasMatthews: Eso es lo que [wikipedia] (http://en.wikipedia.org/wiki/Operators_in_C_and_C%2B%2B#Member_and_pointer_operators) lo llama. El estándar de C++ simplemente lo llama 'operator->'. –