gdb 正在跳过行

2024-03-10

我在理解 gdb 时遇到一些问题。

我有一个主要功能,我自己写了这个主要功能。

这个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_;

线路已被调用两次,为什么?

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();

另外,当我“下一步”时,上面的行没有被调用,为什么?

提前致谢。


您正在进入的库是使用优化和调试符号构建的(很可能是-g -O2,这是 Linux 构建的默认值)。

调试优化的代码有些困难,因为控制流优化会导致代码“跳转”,某些变量变成“<optimized out>", etc.

您可以使用以下命令重建库CXXFLAGS = -g -O0,或者您可以学习在优化的情况下进行调试。

后者是一项非常有用的技能,因为很多时候你的程序都会only在优化模式下崩溃,无论如何你都必须在该模式下调试它。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

gdb 正在跳过行 的相关文章

随机推荐