我想檢查gdb中的std :: vector的內容,但是我沒有訪問_M_impl,因爲我使用的是icc,而不是gcc,我該怎麼做?爲了簡單起見,我們假設它是一個std :: vector。如何使用icc編譯器檢查gdb中std :: vector的內容?
有一個非常好的答案here但這不起作用,如果我使用icc,錯誤消息是「沒有成員或方法名爲_M_impl」。似乎有一個很好的調試工具集here,但它也依賴於_M_impl。
我想檢查gdb中的std :: vector的內容,但是我沒有訪問_M_impl,因爲我使用的是icc,而不是gcc,我該怎麼做?爲了簡單起見,我們假設它是一個std :: vector。如何使用icc編譯器檢查gdb中std :: vector的內容?
有一個非常好的答案here但這不起作用,如果我使用icc,錯誤消息是「沒有成員或方法名爲_M_impl」。似乎有一個很好的調試工具集here,但它也依賴於_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:
(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"
該std::vector
模板guarantees the data is stored contiguously。如果您獲取前面元素的地址(例如,&v[0]
),則可以通過C樣式數組訪問矢量中的任何其他元素。這並不要求您將STL的源代碼提供給調試器。
與此有些搞亂後,似乎v.front()
和v.begin()
有可能內聯和GDB沒有找到他們。我會繼續尋找,但我個人簡單地將int* i = &v[0]
行添加到源文件,然後在調試時使用i
上的GDB命令。請注意,編譯器可以自由刪除那些死代碼。您可能需要輸出i
的值以避免這種情況發生,或者根本無法啓動優化。
通常,當我處理的調試器的容器類,我建立的元素的引用,作爲一個局部變量,所以很容易在調試器中看到,而不會在容器實現方面喋喋不休。
這是一個人爲的例子。
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 */
}
這是我使用的習語。
+1 7年後,gdb仍然無法以合理的方式展示容器。甚至沒有字符串... – 2015-10-01 19:04:56
沒有icc限制:https://stackoverflow.com/questions/253099/how-do-i-print-the-elements-of-ac-vector-in-gdb – 2017-09-24 10:28:19