根据类的大小自动按值或引用传递类
Automatically pass a class by value or by reference depending on its size
本文关键字:引用 更新时间:2023-10-16
我有这个类,我想在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;
}
类似的东西?
typedef typename mpl::if_c<(sizeof(T) <= MAX), T, T&>::type P;
P param = p;
但我认为编译器会自动为您优化它
相关文章:
- 将对象数组的引用传递给函数
- 什么时候在C++中返回常量引用是个好主意
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 何时在引用或唯一指针上使用移动语义
- 如何在c++中使用引用实现类似python的行为
- 编译C++时未定义的引用
- Ctypes wstring通过引用传递
- c++r值引用应用于函数指针
- 理解c++中的引用
- C++取消引用指针.为什么会发生变化
- 如何修复此错误:未定义对"距离(浮点数,浮点数,浮点数,浮点数,浮点数)"的引用
- 我的项目不会像"undefined reference to `grpc::g_core_codegen_interface'"那样使用未定义的引用错误进行编译
- C++Boost Asio Pool线程,带有lambda函数和传递引用变量
- 强制转换为引用类型
- 引用一个已擦除类型(void*)的指针
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- 具有默认值的引用获取函数
- 如何使用基类指针引用派生类成员
- 使用取消引用的指针的多态性会产生意外的结果.为什么?
- 如何引用基类的派生类?