std::unique_ptr<T,D>
被指定为不像您期望的那样存储T*
,而是存储std::unique_ptr<T,D>::pointer
类型的对象。如果存在这种类型,则基本上定义为D::pointer
,否则定义为T*
。因此,您可以通过适当地自定义删除器来自定义基础原始指针类型。
什么时候这样做是个好主意?它是干什么用的?我能找到的唯一讨论是this note,它暗示“在共享内存环境中更好地支持容器和智能指针”,但这并没有完全消除很多光。
答案 0 :(得分:6)
显然,当deleter
对T*
值不起作用时,会使用它。这就是deleter
可以指定与T*
不同的数据类型的原因。一个常见的用例是Win32句柄:
答案 1 :(得分:6)
最初的动机是允许使用boost::offset_ptr
作为unique_ptr
下的表示,这样可以在进程共享内存中使用unique_ptr
。进程共享内存中的结构不应包含指针或引用,只能包含偏移量。
我很高兴地了解到相同的功能在Windows API中非常有用。