问题可能有点令人困惑,但这个概念相对简单。
我有一个函数,它传递任何给定的非静态类方法和对象指针,并绑定它们以产生一个简单的函数指针(见下面的代码),
我有一个特定的签名(返回类型为void,类型为int的一个参数),我希望该方法为:
头文件:
//method_pointer.hpp
#include <boost/bind.hpp>
#include <boost/function.hpp>
class A
{
public:
void aMethod( int );
};
class B
{
public:
template < class T >
B( boost::function< void ( int ) > method_ptr,
T * obj_ptr )
{
bCallAMethod( boost::bind( method_ptr, obj_ptr, _1 ) );
}
void bCallAMethod( boost::function< void (int ) > );
};
源文件:
// method_pointer.cpp
#include <cstdio>
#include "method_pointer.hpp"
void A::aMethod( int x )
{
printf("My number: %d\n", x);
}
void B::bCallAMethod( boost::function<void ( int ) > method_ptr )
{
method_ptr( 5 );
}
int main( void )
{
A a;
B b( &A::aMethod, &a );
return 1;
}
主代码实例化A类对象;然后通过将A的方法和实例传递给构造函数来实例化B类的对象。然后B应该能够通过此boost :: function调用A中的方法。
如果我知道传入了哪种方法(例如&amp; A :: aMethod),我知道如何做到这一点,但目标是推广到具有该签名的任何方法。
我收到编译错误
$ g++ method_pointer.cpp -lboost_system -lrt
method_pointer.cpp: In function ‘int main()’:
method_pointer.cpp:18:11: error: invalid use of non-static member function ‘void A::aMethod(int)’
有什么想法吗?
我也愿意保持一致,并尽可能为类模板使用一些boost函数。
答案 0 :(得分:0)
您需要将B
构造函数的原型更改为:
template<typename T>
B (void (T::*method_ptr)(int), T * obj_ptr)