2016-11-17 83 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 
匹配