2008-11-26 97 views
15

我想检查gdb中的std :: vector的内容,但是我没有访问_M_impl,因为我使用的是icc,而不是gcc,我该怎么做?为了简单起见,我们假设它是一个std :: vector。如何使用icc编译器检查gdb中std :: vector的内容?

有一个非常好的答案here但这不起作用,如果我使用icc,错误消息是“没有成员或方法名为_M_impl”。似乎有一个很好的调试工具集here,但它也依赖于_M_impl。

+2

+1 7年后,gdb仍然无法以合理的方式展示容器。甚至没有字符串... – 2015-10-01 19:04:56

+0

没有icc限制:https://stackoverflow.com/questions/253099/how-do-i-print-the-elements-of-ac-vector-in-gdb – 2017-09-24 10:28:19

回答

10

不知道这将适用于您的载体,但它对我有效。

#include <string> 
#include <vector> 

int main() { 
    std::vector<std::string> vec; 
    vec.push_back("Hello"); 
    vec.push_back("world"); 
    vec.push_back("!"); 
    return 0; 
} 

GDB:

(gdb) break source.cpp:8 
(gdb) run 
(gdb) p vec.begin() 
$1 = { 
    _M_current = 0x300340 
} 
(gdb) p $1._M_current->c_str() 
$2 = 0x3002fc "Hello" 
(gdb) p $1._M_current +1 
$3 = (string *) 0x300344 
(gdb) p $3->c_str() 
$4 = 0x30032c "world" 
0

std::vector模板guarantees the data is stored contiguously。如果您获取前面元素的地址(例如,&v[0]),则可以通过C样式数组访问矢量中的任何其他元素。这并不要求您将STL的源代码提供给调试器。


与此有些搞乱后,似乎v.front()v.begin()有可能内联和GDB没有找到他们。我会继续寻找,但我个人简单地将int* i = &v[0]行添加到源文件,然后在调试时使用i上的GDB命令。请注意,编译器可以自由删除那些死代码。您可能需要输出i的值以避免这种情况发生,或者根本无法启动优化。

3

通常,当我处理的调试器的容器类,我建立的元素的引用,作为一个局部变量,所以很容易在调试器中看到,而不会在容器实现方面喋喋不休。

这是一个人为的例子。

vector<WeirdStructure> myWeird; 

/* push back a lot of stuff into the vector */ 

size_t z; 
for (z = 0; z < myWeird.size(); z++) 
{ 
    WeirdStructure& weird = myWeird[z]; 

    /* at this point weird is directly observable by the debugger */ 

    /* your code to manipulate weird goes here */ 
} 

这是我使用的习语。

相关问题