在我的代码中,我有一个STL向量,它包含指向对象的指针。 我这样编码的原因是因为我必须从不同的地方操纵对象本身。
std::vector<Object*> objects;
for (int i = 0; i < 10; i++) {
Object* o = new Object(i);
objects.push_back(o);
}
此代码假设Object是一个接受整数作为构造函数参数的对象。假设在for循环结束后我使用GDB断点,我需要做什么才能轻松查看向量中的对象?
当我做&#34; p对象&#34;它只列出了完全预期的指针地址,但我想看到每个对象也保存的整数变量。我试过&#34; p objects [0]&#34;但这会返回&#34;无法找到operator []&#34;。
有没有人遇到过这个问题?或者知道如何解决这个问题? 我的目标是能够在这些对象的指针存储在STL向量中时查看GDB实际拥有的对象。
答案 0 :(得分:2)
这肯定是已定义的,但对于GCC,您可以这样做:
print **(v._M_impl._M_start)@1
其中v
表示向量,1
表示索引。您需要取消引用两次才能获得该值。
struct Object
{
int n;
Object(int n)
: n(n) { }
};
int main()
{
std::vector<Object*> v;
v.push_back(new Object{42});
v.size(); // where we breakpoint
// release our memory at some point
}
我们的测试运行:
(gdb) break 16
Breakpoint 1 at 0x400aae: file test.cpp, line 16.
(gdb) run
Starting program: a.out
Breakpoint 1, main () at test.cpp:16
16 v.size(); // where we breakpoint
(gdb) print v
$1 = {<std::_Vector_base<Object*, std::allocator<Object*> >> = {
_M_impl = {<std::allocator<Object*>> = {<__gnu_cxx::new_allocator<Object*>> = {<No data fields>}, <No data fields>}, _M_start = 0x604030, _M_finish = 0x604038, _M_end_of_storage = 0x604038}}, <No data fields>}
(gdb) print **(v._M_impl._M_start)@1
$2 = {{n = 42}}
答案 1 :(得分:0)
这是一个接一个打印值的函数:
define pv
set $pvPOS_ = 0
while $arg0._M_impl._M_start + $pvPOS_ != $arg0._M_impl._M_finish
print **($arg0._M_impl._M_start + $pvPOS_)
set $pvPOS_ = $pvPOS_ + 1
end
end
用作pv my_vec