如何从静态函数访问成员变量

时间:2014-10-25 06:59:49

标签: c++

我需要注册到第三方dll提供的回调函数,这个函数不接受任何参数,因此我不能将“this”传递给它。这里的pData只是数据。

//This is declared as static function in my class
void CMyClass::ThirdPartyCallBack(void *pData)
{
  //How to access the member variables of the class
}

如何在不使用全局变量的情况下执行此操作,感谢您的关注和时间

2 个答案:

答案 0 :(得分:0)

您可以创建一个上下文指针表,该表与一个' thunks'用作DLL的回调函数:

class foo {
public:
    void callback(void* data);
};

enum {
    kMAX_CALLBACKS = 3,
};

foo* context_table [kMAX_CALLBACKS] = {
        0,
        0,
        0

        // however many you might need...
};

extern "C" void callback_0( void* data)
{
        foo* ctx = context_table[0];

        ctx->callback(data);
}


extern "C" void callback_1( void* data)
{
        foo* ctx = context_table[1];

        ctx->callback(data);
}

extern "C" void callback_2( void* data)
{
        foo* ctx = context_table[2];

        ctx->callback(data);
}

// ....

extern "C" {
typedef void (*dll_callback)(void*);
}

dll_callback callback_table[kMAX_CALLBACKS] = {
        callback_0,
        callback_1,
        callback_2

        // however many you might need...
};


dll_callback set_callback_context(foo* ctx)
{
    for (int i =0; i < kMAX_CALLBACKS; ++i) {
        if (context_table[i] == 0) {
            context_table[i] = ctx;
            return callback_table[i];
        }
    }

    return 0;
}

void clear_callback_context(foo* ctx)
{
    for (int i =0; i < kMAX_CALLBACKS; ++i) {
        if (context_table[i] == ctx) {
            context_table[i] = 0;
            return;
        }
    }
}

现在,当你需要设置回调foo::callback()时,传递DLLs函数来设置回调,例如:

third_party_set_callback( set_callback_context(foo_instance_ptr));

并且回调将以foo:callback()结尾,并带有相应的this指针。

答案 1 :(得分:0)

void *是指向你喜欢的任何东西的指针。您可以将任何您喜欢的内容作为数据指针传递给dll,例如“this”。在回调中,您将其转换回对象指针。