Что такое ->* Оператор в C ++?
-
21-09-2019 - |
Вопрос
C ++ продолжает удивлять меня. Сегодня я узнал об операторе ->*. Это перегружается, но я понятия не имею, как это вызвать. Мне удается перегрузить его в своем классе, но я понятия не имею, как это назвать.
struct B { int a; };
struct A
{
typedef int (A::*a_func)(void);
B *p;
int a,b,c;
A() { a=0; }
A(int bb) { b=b; c=b; }
int operator + (int a) { return 2; }
int operator ->* (a_func a) { return 99; }
int operator ->* (int a) { return 94; }
int operator * (int a) { return 2; }
B* operator -> () { return p; }
int ff() { return 4; }
};
void main()
{
A a;
A*p = &a;
a + 2;
}
редактировать:
Спасибо ответу. Чтобы вызвать перегруженную функцию, которую я пишу
void main()
{
A a;
A*p = &a;
a + 2;
a->a;
A::a_func f = &A::ff;
(&a->*f)();
(a->*f); //this
}
Решение
Перегружен ->*
Оператор является бинарным оператором (пока .*
не перегружается). Он интерпретируется как обычный бинарный оператор, поэтому в оригинальном случае, чтобы назвать этот оператор, вы должны сделать что -то вроде
A a;
B* p = a->*2; // calls A::operator->*(int)
То, что вы читаете в ответе PIOTR, относится к встроенный Операторы, а не к вашему перегруженному. То, что вы называете в своем дополнительном примере, также встроенный оператор, а не ваш перегруженный. Чтобы вызвать перегруженного оператора, вы должны делать то, что я делаю в своем примере выше.
Другие советы
Как .*
, ->*
используется с указателями к участникам. Есть целый раздел на C ++ FAQ Lite посвящен указателям к членам.
#include <iostream>
struct foo {
void bar(void) { std::cout << "foo::bar" << std::endl; }
void baz(void) { std::cout << "foo::baz" << std::endl; }
};
int main(void) {
foo *obj = new foo;
void (foo::*ptr)(void);
ptr = &foo::bar;
(obj->*ptr)();
ptr = &foo::baz;
(obj->*ptr)();
return 0;
}
Как и любой другой Opperator, вы также можете назвать это явно:
a.operator->*(2);