我想检查 gdb 中 std::vector 的内容,但我无权访问 _M_impl,因为我使用的是 icc,而不是 gcc,我该怎么做?为简单起见,假设它是一个 std::vector 。
这里有一个非常好的答案,但是如果我使用 icc,这将不起作用,错误消息是“没有名为 _M_impl 的成员或方法”。这里似乎有一个不错的调试工具集,但它也依赖于_M_impl。
不确定这是否适用于您的矢量,但它对我有用。
#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) 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"
通常我在调试器中处理容器类时,会构建一个对元素的引用,作为局部变量,因此在调试器中很容易看到,而无需在容器实现中胡思乱想。
这是一个人为的例子。
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 */
}
这就是我使用的成语。
std::vector
模板保证数据连续存储。如果您获取前面元素的地址(例如,&v[0]
),则可以通过 C 样式数组访问向量中的任何其他元素。这并不要求您将 STL 的源代码提供给您的调试器。
在弄乱了一些之后,似乎v.front()
并且v.begin()
很可能是内联的,而 GDB 没有找到它们。我会继续寻找,但就我个人而言,我只是将这一行添加int* i = &v[0]
到源文件中,然后i
在调试时使用 GDB 命令。请注意,编译器可以自由删除该死代码。您可能需要输出 的值i
来避免这种情况,或者根本不启动优化。