Из сообщения в блоге Доступ к закрытым членам: более безопасная гадость от Johannes Schaub - litb:
template<typename Tag, typename Tag::type M>
struct Rob {
friend typename Tag::type get(Tag) {
return M;
}
};
// use
struct A {
A(int a):a(a) { }
private:
int a;
};
// tag used to access A::a
struct A_f {
typedef int A::*type;
friend type get(A_f);
};
template struct Rob<A_f, &A::a>;
int main() {
A a(42);
std::cout << "proof: " << a.*get(A_f()) << std::endl;
}
как функция get
может быть вызвана из объекта a
, так как она не определена внутри class A
?
EDIT:
Я не понимаю, почему get должен иметь тег как параметр вместо a.*get<A_f>()
= > ok из-за механизма ADL