我有一个要作为LPARAM参数传递给Windows的类。由于它足够小,可以放入LPARAM中,因此我想按值传递它,但是如果它以后扩展,我希望它自动切换为按引用传递。
我会用类似的东西typedef boost::call_traits<CMyClass>::param_type CMyClassParam;
应该是const CMyClass
或const CMyClass&
取决于sizeof(CMyClass) <= sizeof(LPARAM)
但是call_traits仅优化小型POD,而不优化小型类。
通过Anycorn的建议来处理typedef: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;
}
最佳答案
这样的东西?
typedef typename mpl::if_c<(sizeof(T) <= MAX), T, T&>::type P;
P param = p;
但我认为编译器会自动为您优化