美好的一天!关于智能指针的小问题。一般来说,我有指向BYTE数组的指针,我想使用std::shared_ptr
而不是普通指针。这是我的指针示例
shared_ptr<BYTE> pointer(new BYTE[100]);
LPBYTE *old_pointer = pointer;
当然这是无效的例子,但我如何将我的smartpointer分配给其他通用指针?
答案 0 :(得分:4)
你可能要求
std::shared_ptr<std::array<BYTE,100>> pointer(make_shared<std::array<BYTE,100>>());
LPBYTE old_pointer = pointer.get()->data();
要获得另一个引用,您可以简单地使用这样的语句
// increases reference count
std::shared_ptr<std::array<BYTE,100>> pointer2 = pointer;
请在此处查看详细文档:std::shared_ptr
constructor和std::shared_ptr::get()
。
虽然记得:
使用std::shared_ptr::get()
访问智能指针的指针可以绕过使用std::shared_ptr
提供的语义和功能。除非你非常清楚你在old_pointer
做了什么,以及它是否还在范围内,否则这是非常沮丧的。
答案 1 :(得分:0)
您可以使用get_pointer(shared_ptr&lt;&gt;)
访问原始指针BYTE * raw_pointer = get_pointer(指针);
正如其他人所指出的那样,抓住原始指针意味着你现在有一个不被计算的参考,如果不小心就会有潜在的危险情况。
此外,如果您使用shared_ptr&lt;&gt;要保存指向原始数组的指针,需要在原始指针上调用delete []而不是删除。这意味着您需要一个自定义删除器。我意识到你的例子可能是说明性的而不是文字的,但仍然认为值得指出这一点。
答案 2 :(得分:0)
boost::shared_ptr的最新版本可以保存动态分配的数组。该功能正被添加到Library Fundamentals TS(标准化过程的一部分)。