以下是我要调试的代码段:
当我尝试使用GDB进行调试时,在循环结束for i = 0
之后,它不会跳转到循环for i = 1
内的第一行。相反,它会跳到中间的另一条线,然后跳到第一条线。我无法弄清楚为什么以及如何解决它。请给我你的意见。
for(i = 0; i < fileSum; i++)
{
char *fileName ; //= NULL;
// fileName = GetFileName(dataset->groundTruthFolder, trainImageFiles[i], dataset->groundTruthExtension);
fileName = new char[strlen(dataset->groundTruthFolder) + strlen(trainImageFiles[i]) + strlen(dataset->groundTruthExtension) + 1];
sprintf(fileName, "%s%s%s", dataset->groundTruthFolder, trainImageFiles[i], dataset->groundTruthExtension);
printf("GetFileName: fileName-%s \n", fileName);
LLabelImage groundTruth(fileName, domain);
// delete[] fileName;
// fileName = NULL;
int width = groundTruth.GetWidth(), height = groundTruth.GetHeight();
int subWidth = (width + subSample - 1) / subSample;
int subHeight = (height + subSample - 1) / subSample;
for(k = 0; k < subHeight; k++) for(j = 0; j < subWidth; j++)
{
unsigned char gtVal = groundTruth(j * subSample, k * subSample, 0);
if(gtVal > 0) classCounts[gtVal - 1]++, total++;
printf("k = %d,j = %d, gtVal = %d\n", k, j, gtVal);
}
int dummy = 0;
printf("i = %d\n", i);
}
这是gdb控制台的快照:
Breakpoint 2, LDenseUnaryPixelPotential::InitTrainData (this=0x80aad08, trainImageFiles=...) at potential.cpp:665
665 int dummy = 0;
(gdb) n
666 printf("i = %d\n", i);
(gdb) n
i = 1
650 LLabelImage groundTruth(fileName, domain);
(gdb) n
640 for(i = 0; i < fileSum; i++)
(gdb) n
Breakpoint 1, LDenseUnaryPixelPotential::InitTrainData (this=0x80aad08, trainImageFiles=...) at potential.cpp:645
645 fileName = new char[strlen(dataset->groundTruthFolder) + strlen(trainImageFiles[i]) + strlen(dataset->groundTruthExtension) + 1];
(gdb)
请注意,控件从666到650然后再到640,而不是直接从666到640。
以前,我正在使用-g选项进行编译,现在我使用 -g -O0 选项进行编译。仍然存在同样的问题。
这是我的Makefile:
CC = g++
OBJS = main.o
SOURCES = main.cpp
LIBS = -lIL -pthread
EXE = ale
FLAGS = -g -O0 -Wno-write-strings
$(EXE): .
$(CC) $(FLAGS) -c $(SOURCES) -o $(OBJS)
$(CC) -o $(EXE) $(OBJS) $(LIBS)
clean:
rm -rf *.o ale
答案 0 :(得分:1)
实际上,我进一步调试并发现当控件到达循环结束时,正在调用“LLabelImage”的析构函数来删除数据。
答案 1 :(得分:0)
当我尝试使用GDB进行调试时,在i = 0的循环结束后,它不会跳转到循环内的第一行,因为i = 1。
-O0
编译代码不应该发生这种情况。
要么不是那么编译(如果你编译一个可执行文件,但是错误地调试另一个,可能会发生),或者你的GCC坏了,并产生错误的调试行信息。