我喜欢用任意类型的T将一个空指针转换回unique_ptr<T>,这样我就可以取消对它的内容的引用。但下面是一个简单的例子:
#include <memory>
class Foo {
public: Foo(){};
};
int main() {
std::unique_ptr<Foo> p1 (new Foo);
void *p2 = (void*)&p1;
return 0;
}我得到了以下错误,但无法进行强制转换:
$ gdb ./unique-ptr
GNU gdb (Ubuntu 7.7.1-0ubuntu5~14.04.2) 7.7.1
...
(gdb) b 10
Breakpoint 1 at 0x400682: file unique-ptr.cc, line 10.
(gdb) run
Starting program: /home/vagrant/c-test/unique-ptr/unique-ptr
Breakpoint 1, main () at unique-ptr.cc:10
10 return 0;
(gdb) p p1
$1 = std::unique_ptr<Foo> containing 0x603010
(gdb) p p2
$2 = (void *) 0x7fffffffea40
(gdb) p *(std::unique_ptr<Foo>*)p2
A syntax error in expression, near `)p2'.
(gdb) 实际用例是,我喜欢打印容器类中包含的unique_ptr内容,但这是目前阻碍我进一步研究的问题。
发布于 2016-11-17 22:11:36
使用模板创建的实际类型名称不是std::unique_ptr<Foo>。获取实名制名称,并:
(gdb) ptype p1
type = class std::unique_ptr<Foo, std::default_delete<Foo> > [with _Tp = Foo, _Dp = std::default_delete<Foo>] {
private:
__tuple_type _M_t;
...由此,我发现gdb能够识别std::unique_ptr<Foo, std::default_delete<Foo> >,并且我能够做到:
(gdb) p *(std::unique_ptr<Foo, std::default_delete<Foo> > *)p2
$3 = std::unique_ptr<Foo> containing 0x603010与之匹配
(gdb) p p1
$1 = std::unique_ptr<Foo> containing 0x603010https://stackoverflow.com/questions/40665973
复制相似问题