我喜欢使用任意类型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的内容,但这是目前阻止我走得更远的问题。
答案 0 :(得分:3)
使用模板创建的实际类型名称不是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