4

我有这个类,我想将它作为 LPARAM 参数传递给 Windows。由于它足够小以适合 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;
}
4

1 回答 1

2

类似的东西?

typedef typename mpl::if_c<(sizeof(T) <= MAX), T, T&>::type P;
P param = p;

但我认为编译器会自动为你优化这个

于 2012-04-09T08:20:15.680 回答