我有这个类,我想在Windows上传递LPARAM参数。因为它足够小以适应LPARAM内部我想通过值传递它,但是如果它稍后扩展我希望它自动切换到通过引用传递。
我会使用像
typedef boost::call_traits<CMyClass>::param_type CMyClassParam;
应该是 const CMyClass
或const CMyClass&
取决于sizeof(CMyClass) <= sizeof(LPARAM)
但call_traits只优化小POD,而不是小类。
typedef由Anycorn的建议处理:
typedef boost::mpl::if_c<(sizeof(CMyClass) <= sizeof(LPARAM)), CMyClass, CMyClass&>::type CMyClassParam;
然后,我如何在CMyClassParam和LPARAM之间进行转换 (如果您不知道,LPARAM是int,足够长以存储指针)
CMyClass::operator LPARAM()
{
// must be either
return *(LPARAM*)this;
//or
return reinterpret_cast<LPARAM>(this);
}
//so that I may call:
void SomeWinFunc(LPARAM p);
CMyClass vi;
SomeWinFunc(vi);
// and then get it back:
void SomeWinCallback(LPARAM p)
{
CMyClassParam vi = (?????)p;
// which should translate into either
CMyClass ti = *(CMyClass*)(&p); // make a bitwise copy
// or
CMyClass& ti = *(CMYClass*)p;
}
答案 0 :(得分:2)
那样的东西?
typedef typename mpl::if_c<(sizeof(T) <= MAX), T, T&>::type P;
P param = p;
但我认为编译器会自动为您优化