Wow. C++ nigdy nie przestaje mnie zaskakiwać swoją niesamowitością.
In a template definition, unqualified names will no longer find members of a dependent base (as specified by [temp.dep]/3 in the C++ standard). For example,
template <typename T> struct B {
int m;
int n;
int f();
int g();
};
int n;
int g();
template <typename T> struct C : B<T> {
void h()
{
m = 0; // error
f(); // error
n = 0; // ::n is modified
g(); // ::g is called
}
};
You must make the names dependent, e.g. by prefixing them with this->. Here is the corrected definition of C::h,
template <typename T> void C<T>::h()
{
this->m = 0;
this->f();
this->n = 0
this->g();
}
As an alternative solution (unfortunately not backwards compatible with GCC 3.3), you may use using declarations instead of this->:
template <typename T> struct C : B<T> {
using B<T>::m;
using B<T>::f;
using B<T>::n;
using B<T>::g;
void h()
{
m = 0;
f();
n = 0;
g();
}
};
to tylko wszelkiego rodzaju szalone. Dzięki, David.
Oto "/ temp.dep 3" odcinek standardowego [ISO/IEC 14882: 2003], że są one odnoszące się do:
In the definition of a class template or a member of a class template, if a base class of the class template depends on a template-parameter, the base class scope is not examined during unqualified name lookup either at the point of definition of the class template or member or during an instantiation of the class template or member. [Example:
typedef double A;
template<class T> class B {
typedef int A;
};
template<class T> struct X : B<T> {
A a; // a has typedouble
};
The type name A
in the definition of X<T>
binds to the typedef name defined in the global namespace scope, not to the typedef name defined in the base class B<T>
. ] [Example:
struct A {
struct B { /* ... */ };
int a;
int Y;
};
int a;
template<class T> struct Y : T {
struct B { /* ... */ };
B b; //The B defined in Y
void f(int i) { a = i; } // ::a
Y* p; // Y<T>
};
Y<A> ya;
The members A::B
, A::a
, and A::Y
of the template argument A
do not affect the binding of names in Y<A>
. ]
Zobacz [W klasie pochodzącej z szablonu, dlaczego muszę kwalifikować nazwy członków klasy podstawowej za pomocą "this->" wewnątrz funkcji członka?] (Http://stackoverflow.com/questions/7908248/in-a- Templated-derived-class-why-do-i-need-to-qualify-base-class-member-names-w) – curiousguy