クラステンプレートなしでコールバックを行うことができました。しかし、私の必要条件は、テンプレートフォームにあるクラスオブジェクトを渡すことでコールバックを実装することです。私はメイン()に自分の意思を書いたが、何とか私はそれを働かせることができない。クラステンプレートをC++のコールバックとして使用
私の現在の問題では、boostとC++ 11は使用できません。どんな助けでも大歓迎です。
// TestProj.cpp : Defines the entry point for the console application.
//
#include "stdafx.h"
#include "glb.h"
#include "Test.h"
#include <iostream>
using namespace std;
class MyCallBack
{
private:
class Callback
{
public:
virtual ~Callback() { }
virtual void call() = 0;
};
template <typename T>
class ClassCallback : public Callback
{
private:
T* object;
void (T::*callback)();
public:
ClassCallback(T* obj, void (T::*clbk)()) : object(obj), callback(clbk) {}
virtual void call() { (object->*callback)(); }
};
private:
Callback* callback;
public:
MyCallBack() : callback(NULL) { }
~MyCallBack() { delete callback; }
template <typename T>
MyCallBack(T* obj, void (T::*clbk)())
{
callback = new ClassCallback<T>(obj,clbk);
}
void operator()()
{
callback->call();
}
};
typedef enum {
EVENT1 = 1,
EVENT2 = 2,
EVENT3 = 4,
EVENT4 = 8
} MyEvent_t;
template <class EventT>
class EventHandler
{
public:
virtual void on_event(EventT _event) = 0;
};
class MyHandler:public EventHandler<MyEvent_t>{
virtual void on_event(MyEvent_t _event){
switch(_event){
case EVENT1:
break;
case EVENT2:
break;
}
}
};
int _tmain(int argc, _TCHAR* argv[])
{
EventHandler<MyEvent_t> *my_handler = new MyHandler();
MyCallBack rcb(my_handler,&MyHandler<MyEvent_t>::on_event);
// to check the callback
rcb();
return 0;
}
ありがとうございました!
私たちは、あなたが問題に、より特異的であることができるならば、あなたを助け、および/またはコードを減らすことができます確信しています。 – Potatoswatter
まず、 'on_event'は' EventT'を期待しています。あなたの 'void(T :: * callback)();'はこれを考慮しません。 –
HI Barrett、はい私は引数がないことを知っています。私の質問はそれを追加する方法です。私はC++とテンプレートを初めて使っています。また、ラインMyCallBack rcb(my_handler、&MyHandler :: on_event); RSとして指摘されているタイプがあります。 MyhandlerではなくEvent Handlerでなければなりません。 –
Jain