Указатель функции нестатической функции-члена класса

Я хочу определить функцию-член в классе и использовать ее указатель. Я знаю, что могу использовать статическую функцию-член, но проблема в том, что я могу получить доступ только к статическим членам класса. Есть ли способ, отличный от статической функции-члена, чтобы получить указатель функции.


Чтобы быть более конкретным: есть библиотека, которую я использую, которая получает указатель на функцию в качестве входных данных. Я хочу написать функцию-член и назначить ее указатель на эту внешнюю библиотеку. Должен ли я создать объект класса или использовать этот указатель для этого?


person Roy    schedule 14.01.2013    source источник
comment
Подсказка: вам нужен объект для доступа к нестатическим членам.   -  person Mark Garcia    schedule 14.01.2013
comment
В Интернете есть множество руководств: D здесь и здесь есть несколько примеров.   -  person PaperBirdMaster    schedule 14.01.2013
comment
Да.   -  person n. 1.8e9-where's-my-share m.    schedule 14.01.2013


Ответы (2)


Вы можете получить указатель на метод, но он должен вызываться с объектом

typedef void (T::*MethodPtr) ();
MethodPtr method = &T::MethodA;
T *obj = new T();
obj->*method();

Если вам нужен необъектный указатель и вы хотите использовать объект, вам нужно где-то хранить экземпляр объекта, но вы ограничены использованием только одного объекта (синглтона).

class T {
  static T *instance;
public:
  T::T() {
    instance = this;
  }
  static void func() {
    instance->doStuff();
  }
  void doStuff() {}
};

Если библиотека поддерживает пользовательские данные для указателей функций, у вас может быть несколько экземпляров.

class T {
public:
  static void func(void *instance) {
    ((T*)instance)->doStuff();
  }
  void doStuff() {}
};
person kravemir    schedule 14.01.2013
comment
На самом деле я делал это, но у меня возникла проблема: stackoverflow.com/questions/14314507/ - person Roy; 14.01.2013

  • If:
  • вы хотите получить указатель функции нестатического члена из класса
  • И используйте его внутри класса:
  • Затем: Это может работать, потому что когда вы получаете адрес функции-члена, есть указатель «this». Синтаксис не был очевиден для меня, и он может выглядеть несколько уродливым, но не СЛИШКОМ плохим. Это может быть не ново для настоящих экспертов, но я давно хотел иметь это в своем наборе трюков.

Вот полный пример программы:

#include <iostream>
class CTestFncPtr
{
public:
    CTestFncPtr(int data) : mData(data)
    {
//      Switch = &CTestFncPtr::SwitchC; // Won't compile - wrong function prototype - this is type safe
        if (data == 1)
            Switch = &CTestFncPtr::SwitchA;
        else
            Switch = &CTestFncPtr::SwitchB;
    }
    void CallSwitch(char *charData)
    {
        (this->*Switch)(charData);
    }

private:
    void SwitchA(char * charData)
    {
        std::cout << "Called Switch A " << "Class Data is " << mData<<" Parameter is " << charData<< "\n";
        Switch = &CTestFncPtr::SwitchB;
    }
    void SwitchB(char * charData)
    {
        std::cout << "Called Switch B " << "Class Data is " << mData<<" Parameter is " << charData<< "\n";
        Switch = &CTestFncPtr::SwitchA;
    }
    void SwitchC()
    {
    }
    void(CTestFncPtr::*Switch)(char * charData);
    int mData;
};

int main(int argc, char * argv[])
{
    CTestFncPtr item1(1);
    item1.CallSwitch("Item1");
    item1.CallSwitch("Switched call Item 1");
    CTestFncPtr item2(0);
    item2.CallSwitch("Item2");
    item2.CallSwitch("Switched call Item 2");

    return 0;
}
person J Jay Meyer    schedule 04.03.2015