有任何“智能”方法从静态类函数成员获取类对象指针,例如:
class my_class
{
public:
my_class(int a) : v_a(a) {};
static void static_f()
{
my_class* p = GET OBJECT POINTER
std::cout << p->v_a << std::endl;
}
private:
int v_a;
};
我知道这可能是不可能的,但我已经奋斗了2天到目前为止,我已经能够使用模板实现它并在全局范围内声明对象:
template
static void static_f()
{
my_class* p = tp;
std::cout << p->v_a << std::endl;
}
my_class v1(100); // global variable
my_class v2(200); // global variable
v1.static_f(); // main function
v2.static_f(); // main function
它打印出100和200尊重 . 如果我将它声明为局部变量,这将无法工作 . 通过“智能”我的意思是c 11或更高的一些新功能,我不知道 .
Purpose:
我试图封装一个C库的几个函数,其中一个函数需要一个指向函数的指针作为回调,这个回调函数指针不会由我自己调用,而是由库调用,它不接受传递的其他参数作为上下文,所以我不能直接调用它(我在代码中做了,因为我想保持示例尽可能小)或只是传递对象指针 .
Possible solution:
到目前为止,我已经能够通过使用模板和每个对象的全局变量来实现这一目标:
template
class my_class
{
public:
my_class(int v1, int v2)
{
x_var1 = v1;
x_var2 = v2;
*pp = this;
}
void call_callback_for_test()
{
callback();
}
private:
static void callback()
{
my_class* p = reinterpret_cast(*pp);
std::cout << p->x_var1 << " - " << p->x_var2 << std::endl;
}
int x_var1;
int x_var2;
};
void* pv1;
void* pv2;
my_class v1(100, 200);
int main()
{
my_class v2(300, 400);
v1.call_callback_for_test();
v2.call_callback_for_test();
return 0;
}
是的,我觉得可以有一个更好的解决方案使用更新的c功能,例如使用constexpr或元编程(我读了一下他们,我可能是错的)但我只是非常初学者和缺乏经验,或改进这种方法 .