Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > C/C++: Общие вопросы > Указатели на методы класса


Автор: cymtu 24.4.2009, 09:16
Есть класс В, который реализует обычный список элементами которого являються объекта класса А
все переменные класса А закрыты и должны быть закрыты(private), открыты только методы.
Среди переменных класса В есть указатель *pА на класс А, которые посредством методов 
Beg()
End()
Next()
Prev()
перемещается по списку. 
А с помощью методов типа Get_..../Set_.... осуществляется доступ к переменным того элемента, на который указывает *рА.

В свою очередь класс В также является элементом для класс С, который реализует список из этих элементов.
Все переменные класса С закрыты и должны быть закрыты(private), открыты только методы.
Среди переменных класса C есть указатель *pВ на класс В, которые посредством методов 
Beg()
End()
Next()
Prev()
перемещается по списку. 
А с помощью методов типа Get_..../Set_.... осуществляется доступ к переменным того элемента, на который указывает *рВ.

Вопрос:
Как реализовать механизм доступа разработчику, который будет использовать класс C, к методам класса B]B[/B] элемента на который указывает указатель *рВ, но не переменным.
Я понимаю что можно сделать указатель *pB класса C открытым и тогда проблема отпадет, но указатель по условию должен быть private, к нему не должно быть прямого доступа у разработчика.
Читал что-то про указатели на методы класса, но примеров не было. так и не понял.
ПОМОГИТЕ РЕШИТЬ ПРОБЛЕМУ!!!
 smile 

Автор: azesmcar 24.4.2009, 09:30
Цитата(cymtu @  24.4.2009,  09:16 Найти цитируемый пост)
но не переменным.

не понял что это означает? нужен константный доступ? возвращайте константную ссылку/указатель
насчет указателей на функции члены вот пример
Код

class A
{
public:
    void f()
    {
        std::cout << "Hello world!!!" << std::endl;
    }
};

typedef void (A::*memfunc)();
int main()
{
    A obj;
    memfunc f = &A::f;
    (obj.*f)();
}

правда не знаю как это может помочь в данном случае

Автор: Rififi 24.4.2009, 09:37
Читать про паттерны "Aggregation", "Wrapper", "Proxy", "Facade" - возможно что-то удастся применить.

Автор: azesmcar 24.4.2009, 09:38
Rififi

Да, я тоже хотел Прокси предложить, похоже на то что это может помочь, но я пока суть проблемы полностью не осмыслил.

Автор: math64 24.4.2009, 09:47
Код

class A {
  int i;
public:
  int GetI() { return i; }
  void SetI(int _i) { i = _i; }
};
class B {
A* a;
public:
  A* Beg() { ....; return a; }
  A* End() { ...; return a; }
  A* Prev() { ...; return a; }
  A* Next() { ...; return a; }
  A* Get() { return a; }
  const A* Get() const { return a; } 
};
class C {
B* b;
public:
  B* Beg() { ....; return b; }
  B* End() { ...; return b; }
  B* Prev() { ...; return b; }
  B* Next() { ...; return b; }
  B* Get() { return b; }
  const B* Get() const { return b; } 
};

Автор: cymtu 24.4.2009, 10:11
Код

class A {
  int i;
public:
  int GetI() { return i; }
  void SetI(int _i) { i = _i; }
};
class B {
A* a;
public:
  A* Beg() { ....; return a; }
  A* End() { ...; return a; }
  A* Prev() { ...; return a; }
  A* Next() { ...; return a; }
  A* Get() { return a; }
  const A* Get() const { return a; } 
};
class C {
B* b;
public:
  B* Beg() { ....; return b; }
  B* End() { ...; return b; }
  B* Prev() { ...; return b; }
  B* Next() { ...; return b; }
  B* Get() { return b; }
  const B* Get() const { return b; } 
};


Да неплохо пойдет пока smile  всё элегантно и просто, про const я совсем забыл.
Но ещё покапаюсь в
Код

"Aggregation", "Wrapper", "Proxy", "Facade"

Автор: cymtu 25.4.2009, 07:59
Цитата(azesmcar @  24.4.2009,  09:38 Найти цитируемый пост)
Да, я тоже хотел Прокси предложить, похоже на то что это может помочь, но я пока суть проблемы полностью не осмыслил. 


Да "Proxy" оказалось лучшим решением smile 

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)