GDB перепрыгивает через строки - PullRequest
4 голосов
/ 09 ноября 2011

У меня есть некоторые проблемы с пониманием GDB.

У меня есть основная функция, я написал эту основную функцию для себя.

Некоторые строки в этом main, вызывают некоторые функции в библиотеке,я думаю, что имя библиотеки не важно, но это tesseract-ocr.

моя строка в main, которая вызывает функцию, конструктор находится здесь:

choiceItr = new tesseract::ChoiceIterator(itr);

я поставил точку останова на gdbв строке выше и запустите, когда она остановится на этой строке, я использую команду шага для перехода в функцию.

Вот библиотечная функция, которая вызывается:

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 для перехода в функцию.

вот моя консоль 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();

также, когда я "следующий", вышеупомянутые строки не были вызваны, почему?

Спасибо заранее.

1 Ответ

12 голосов
/ 09 ноября 2011

Библиотека, в которую вы входите, была построена с символами оптимизации и отладки (наиболее вероятно, -g -O2, который является значением по умолчанию для сборок Linux).

Отладка оптимизированного кода довольно сложна, так как оптимизация потока управлениязаставляет код «перепрыгивать», некоторые переменные становятся «<optimized out>» и т. д.

Вы можете перестроить библиотеку с помощью CXXFLAGS = -g -O0 или научиться отлаживать с оптимизацией на.

Последнее очень полезное умение, так как много раз ваша программа будет только аварийно завершать работу в оптимизированном режиме, и вам все равно придется ее отлаживать в этом режиме.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...