C ++的可变参数模板功能强大,但编写此类代码却很难。我的问题出现了:如何通过模板传递Class
的构造(参见下面的代码片段)?
注意:因为我想获得一般解决方案,所以构造的参数必须是可变的。此外,我想设置每个参数的默认值。
有人可以帮助我吗?
#include <iostream>
#include <utility>
template< typename R, typename C, typename... Args>
class delegate
{
public:
template<R(C::*F)(Args...)>
struct adapter
{
static R invoke_no_fwd(Args... args)
{
C t; // how to pass the construction function of C through template??? and set default value for each argument
return (t.*F)(args...);
}
};
};
class Class
{
public:
Class(int param)
: m_val(param)
{}
void print(int v)
{
std::cout << "Class: " << v + m_val << std::endl;
}
private:
int m_val;
};
int main(int argc, char** argv)
{
using namespace std;
// because the below code doesn't contain construction info, so it won't compile
typedef void(*function_t)(int);
function_t ptrFunc = (delegate<void, Class, int>::adapter<&Class::print>::invoke_no_fwd);
auto type = (delegate<void, Class, int>::adapter<&Class::print>::invoke_no_fwd);
cout << typeid(type).name() << endl;
return 0;
}
答案 0 :(得分:1)
您可以使用std::integral_constant<typename T, T>
执行以下操作:
template< typename R, typename C, typename... Args>
class delegate
{
public:
template<R(C::*F)(Args...), typename ... Ts>
struct adapter {
static R invoke_no_fwd(Args... args) {
C t((Ts::value)...);
return (t.*F)(args...);
}
};
};
并使用它:
int main()
{
//using namespace std;
typedef void(*function_t)(int);
function_t ptrFunc = (delegate<void, Class, int>::adapter<&Class::print, std::integral_constant<int, 42> >::invoke_no_fwd);
auto type = (delegate<void, Class, int>::adapter<&Class::print, std::integral_constant<int, 42>>::invoke_no_fwd);
ptrFunc(-42);
type(0);
return 0;
}
答案 1 :(得分:0)
alloctor使用宏来调用析构函数。
template<class _Ty> inline
void _Destroy(_Ty _FARQ *_Ptr)
{ // destroy object at _Ptr
_DESTRUCTOR(_Ty, _Ptr);
}
#define _DESTRUCTOR(ty, ptr) (ptr)->~ty()
这可以解决你的问题吗?