[英]Passing any class member function with any number of arguments to a function outside the class
[英]function pointer to any member function with any number of arguments
由于特定的原因,我想要一个函数指针,该指针可以指向该类的任何成员函数,并且可以随时更改。 我想到了如下设置:
//#include <iostream>
//#include <functional>
#include <cstdarg>
class someclass{
public:
someclass(){ func = trial; }
template<typename T, typename... Args> void setfunc(T t, Args... args){
func = t(args...);
}
void trial(){
//do some stuff
}
void trying(int i){
//do other stuff
}
template <typename T>void (someclass::*func)(Args...);
};
int main(){
someclass c;
(c.*(c.func))();
c.setfunc(someclass::trying, 32);
(c.*(c.func))();
}
不幸的是,C ++不允许我这样做,而是给我错误:
data member 'func' cannot be a member template
我读到您不能制作成员变量的模板,当我写时
void (someclass::*func)();
和紧急停堆的Args
在双组分setfunc()
它工作得很好的trial()
而不是trying()
所以我的问题是:是否有解决此问题的方法,或者可以尝试其他方法?
我暂时在这里:
#include <iostream>
#include <functional>
class someclass{
public:
someclass(){
func = std::bind(&someclass::trial, std::placeholders::_1);
}
void setfunc(std::function<void(someclass&)> f){ func = f; }
void trial(){
//do some stuff
//std::cout << "1" << std::endl;
}
void trying(int i){
//do other stuff
//std::cout << "2" << std::endl;
}
std::function<void(someclass&)> func;
};
int main(){
someclass c;
#c.func(); //!!!
c.setfunc(std::bind(&someclass::trying, std::placeholders::_1, 32));
#c.func(c); //!!!
}
我的IDE用#标记行
您可以使用std::function
,例如
class someclass{
public:
someclass(){ func = &someclass::trial; }
void setfunc(std::function<void(someclass&)> f){ func = f; }
void trial(){
//do some stuff
}
void trying(int i){
//do other stuff
}
std::function<void(someclass&)> func;
};
int main(){
someclass c;
c.func(c);
c.setfunc([](someclass& cl){cl.trying(32);});
c.func(c);
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.