2016-11-17 82 views
3

我喜欢用任意类型T将一个空指针转回unique_ptr<T>,以便我可以将它解引用到它的内容。但有以下简单的例子:如何在gdb中将void指针投射到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内容,但这是目前阻止我走得更远的问题。

回答

2

使用模板创建的实际类型名称不是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 0x603010 
匹配