我有一个要作为LPARAM参数传递给Windows的类。由于它足够小,可以放入LPARAM中,因此我想按值传递它,但是如果它以后扩展,我希望它自动切换为按引用传递。

我会用类似的东西
typedef boost::call_traits<CMyClass>::param_type CMyClassParam;
应该是const CMyClassconst 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;

但我认为编译器会自动为您优化

09-06 09:34