我对gdb的理解有一些问题。
我有一个main函数,这个main函数是我自己写的。
其中的一些代码行调用了库中的一些函数,我认为库的名称并不重要,但它是tesseract-ocr。
我在main中调用一个函数,一个构造函数的代码如下:
choiceItr = new tesseract::ChoiceIterator(itr);我在gdb的上面一行上放了一个断点,然后运行,当它停在该行上时,我使用step命令进入函数。
下面是被调用的库函数:
ChoiceIterator::ChoiceIterator(const ResultIterator& result_it) {
ASSERT_HOST(result_it.it_->word() != NULL);
tesseract_ = result_it.tesseract_;
PAGE_RES_IT res_it(*result_it.it_);
WERD_CHOICE* best_choice = res_it.word()->best_choice;
BLOB_CHOICE_LIST_CLIST* choices = best_choice->blob_choices();
if (choices != NULL) {
BLOB_CHOICE_LIST_C_IT blob_choices_it(choices);
for (int blob = 0; blob < result_it.blob_index_; ++blob)
blob_choices_it.forward();
choice_it_ = new BLOB_CHOICE_IT(blob_choices_it.data());
choice_it_->mark_cycle_pt();
} else {
choice_it_ = NULL;
}
}然后,我使用gdb的"next“命令遍历函数。
这是我的gdb控制台:
Breakpoint 1, pixsOfOneWord (langString=0x8049e7c "klm",
imageString=0x8049e71 "paket2.tif", outputData=0x8049c7b,
datapathString=0x8049e6f ".") at deneme234.cpp:161
161 choiceItr = new tesseract::ChoiceIterator(itr);
(gdb) step
tesseract::ChoiceIterator::ChoiceIterator (this=0x819e6f0, result_it=...)
at resultiterator.cpp:234
234 choice_it_ = new BLOB_CHOICE_IT(blob_choices_it.data());
(gdb) next
225 ASSERT_HOST(result_it.it_->word() != NULL);
(gdb) list
220 return it_->word()->box_word->BlobPosition(blob_index_) == SP_DROPCAP;
221 return false;
222 }
223
224 ChoiceIterator::ChoiceIterator(const ResultIterator& result_it) {
225 ASSERT_HOST(result_it.it_->word() != NULL);
226 tesseract_ = result_it.tesseract_;
227 PAGE_RES_IT res_it(*result_it.it_);
228 WERD_CHOICE* best_choice = res_it.word()->best_choice;
229 BLOB_CHOICE_LIST_CLIST* choices = best_choice->blob_choices();
(gdb) next
278 } // namespace tesseract.
(gdb) next
226 tesseract_ = result_it.tesseract_;
(gdb) next
278 } // namespace tesseract.
(gdb) next
226 tesseract_ = result_it.tesseract_;
(gdb) next
230 if (choices != NULL) {
(gdb) 如你所见,
tesseract_ = result_it.tesseract_;line已经被调用了两次,为什么?
PAGE_RES_IT res_it(*result_it.it_);
WERD_CHOICE* best_choice = res_it.word()->best_choice;
BLOB_CHOICE_LIST_CLIST* choices = best_choice->blob_choices();还有当我“下一步”的时候,上面的代码没有被调用,为什么?
谢谢你的提醒。
发布于 2011-11-09 23:51:44
您正在步入的库是使用优化和调试符号(很可能是-g -O2,这是Linux构建的默认符号)构建的。
调试优化的代码有些困难,因为控制流优化会导致代码“跳来跳去”,一些变量变成"<optimized out>",等等。
您可以使用CXXFLAGS = -g -O0重新构建库,也可以学习在启用优化的情况下进行调试。
后者是一项非常有用的技能,因为很多时候你的程序只会在优化模式下崩溃,而且无论如何你都必须在该模式下调试它。
https://stackoverflow.com/questions/8064911
复制相似问题