std::unique_ptr很好,但我发现在DDD或gdb中调试时不太舒服.
我正在使用作为gcc一部分的gdb漂亮打印机(例如/usr/share/gcc-4.8.2/python/libstdcxx/v6/printers.py).这是可读性的一大胜利,例如:
$ print pTest
std::unique_ptr<MyType> containing 0x2cef0a0
Run Code Online (Sandbox Code Playgroud)
但是,取消引用指针不起作用:
$ print *pTest
Could not find operator*.
Run Code Online (Sandbox Code Playgroud)
当我需要访问该值时,我必须手动复制指针并将其强制转换为正确的类型,例如:
print *((MyType*) 0x2cef0a0)
Run Code Online (Sandbox Code Playgroud)
如果进程仍在运行,那么这个版本可以工作(仍然很难但更好):
print *pTest.get() // will not work if analyzing a core dump
Run Code Online (Sandbox Code Playgroud)
Display *pTest在DDD中直接的方法也不起作用.它只会导致以下错误:
<error: Could not find operator*.>
Run Code Online (Sandbox Code Playgroud)
有没有办法在DDD中使用unique_ptr调试C++ 11代码(不像我使用繁琐的解决方法那样打破工作流程)?
我不怕使用gdb命令,但DDD集成将是一个加号.例如,通过双击它们来跟踪数据结构中的指针通常比键入更快.
我已经尝试放弃漂亮的打印机,但它也不是最佳选择.我能想到的最好的是以下内容:
print pTest._M_t->_M_head_impl
Run Code Online (Sandbox Code Playgroud) 我有以下测试程序:
#include<memory>
#include<iostream>
using namespace std;
int main()
{
shared_ptr<int> si(new int(5));
return 0;
}
Run Code Online (Sandbox Code Playgroud)
调试它:
(gdb) l
1 #include<memory>
2 #include<iostream>
3 using namespace std;
4
5 int main()
6 {
7 shared_ptr<int> si(new int(5));
8 return 0;
9 }
10
(gdb) b 8
Breakpoint 1 at 0x400bba: file testshare.cpp, line 8.
(gdb) r
Starting program: /home/x/cpp/x01/a.out
Breakpoint 1, main () at testshare.cpp:8
8 return 0;
(gdb) p si
$1 = std::shared_ptr (count 1, weak 0) 0x614c20
Run Code Online (Sandbox Code Playgroud)
它只打印出指针类型信息si …