具有小对象优化功能的智能指针
Smart pointer with small object optimization
我有一个类的层次结构。基类有一个虚拟析构函数和一些虚拟方法。大多数派生类根本没有成员。一些派生类只有POD成员。
由于这些类中的大多数都没有成员,所以在堆上创建它们并传递unique_ptr
感觉像是在浪费资源。
我想使用一个智能指针,它可以执行小对象优化。该指针应将符合以下条件的所有对象存储在一个特殊缓冲区中,而无需分配新的内存:
- 类仅由vtable指针和可平凡移动的成员组成
- 类没有用户定义的移动运算符
- 班级已经足够小了
关于如何实现这一点,我有两个问题。
首先,如何检测此类类?它不是微不足道的可移动的,因为有虚拟功能。
其次,记住这样的类安全吗?
另外一个问题是:是否存在此类类的已知实现?
不完全确定根据标准这是否严格合法,但我认为这是一种检测类是否多态和无数据的非常便携的方法:
#include <type_traits>
namespace detail
{
struct BaselinePoly
{
virtual ~BaselinePoly();
};
}
template<class T>
struct IsDatalessPolymorphic
: std::integral_constant
<
bool,
std::is_polymorphic<T>::value && sizeof(T) == sizeof(detail::BaselinePoly)
>
{
};
struct Foo
{
virtual ~Foo();
};
struct Bar : Foo {};
struct Baz : Foo { int x; };
int main()
{
static_assert(IsDatalessPolymorphic<Bar>());
static_assert(!IsDatalessPolymorphic<Baz>());
}
隐含的移动和复制操作符应该是极其琐碎的。我怀疑你不会从memcpy
的骗局中得到任何好处。
相关文章:
- 1d 智能指针不适用于语法 (*)++
- 优先顺序:智能指针和类析构函数
- 对于C++中使用智能指针的指针算术限制,有没有一种变通方法
- 智能指针作为无序映射键,并通过引用进行比较
- 智能指针概念所有权和寿命
- 正在理解智能指针,但出现错误:未分配正在释放的指针
- 尝试使用智能指针时引发异常
- 我可以制作指向智能指针的智能指针吗?
- 通过智能指针和转换对基本模板参数进行模板推导
- OpenCV 我应该使用智能指针来防止内存泄漏吗?
- 从堆栈分配的原始指针构造智能指针
- 初始化指向类实例的智能指针并访问其方法
- 如何使用 std::make_shared 创建基类类型的智能指针?
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 编译器不会使用 -std=c++11 编译智能指针
- 具有智能指针的多态性
- C++:矢量分配器行为、内存分配和智能指针
- 在什么情况下,需要共享智能指针而无法使用唯一指针?
- 指向函数签名中的常量智能指针
- 使用智能指针附加的继承对象的深层复制