【发布时间】:2011-02-14 14:14:36
【问题描述】:
我有一个正在调用的函数,它一直运行到它应该返回但不返回的位置。如果我在函数的最后找到一些用于调试的东西,它会显示但函数不会返回。
fetchData 是我指的函数。它被 outputFile 调用。 cout 显示“在此处完成”但不显示“已获取数据”
我知道这段代码很乱,但谁能帮我解决这个问题?
谢谢
//Given an inode return all data of i_block data
char* fetchData(iNode tempInode){
char* data;
data = new char[tempInode.i_size];
this->currentInodeSize = tempInode.i_size;
//Loop through blocks to retrieve data
vector<unsigned int> i_blocks;
i_blocks.reserve(tempInode.i_blocks);
this->currentDataPosition = 0;
cout << "currentDataPosition set to 0" << std::endl;
cout << "i_blocks:" << tempInode.i_blocks << std::endl;
int i = 0;
for(i = 0; i < 12; i++){
if(tempInode.i_block[i] == 0)
break;
i_blocks.push_back(tempInode.i_block[i]);
}
appendIndirectData(tempInode.i_block[12], &i_blocks);
appendDoubleIndirectData(tempInode.i_block[13], &i_blocks);
appendTripleIndirectData(tempInode.i_block[14], &i_blocks);
//Loop through all the block addresses to get the actual data
for(i=0; i < i_blocks.size(); i++){
appendData(i_blocks[i], data);
}
cout << "done here" << std::endl;
return data;
}
void appendData(int block, char* data){
char* tempBuffer;
tempBuffer = new char[this->blockSize];
ifstream file (this->filename, std::ios::binary);
int entryLocation = block*this->blockSize;
file.seekg (entryLocation, ios::beg);
file.read(tempBuffer, this->blockSize);
//Append this block to data
for(int i=0; i < this->blockSize; i++){
data[this->currentDataPosition] = tempBuffer[i];
this->currentDataPosition++;
}
data[this->currentDataPosition] = '\0';
}
void outputFile(iNode file, string filename){
char* data;
cout << "File Transfer Started" << std::endl;
data = this->fetchData(file);
cout << "data fetched" << std::endl;
char *outputFile = (char*)filename.c_str();
ofstream myfile;
myfile.open (outputFile,ios::out|ios::binary);
int i = 0;
for(i=0; i < file.i_size; i++){
myfile << data[i];
}
myfile.close();
cout << "File Transfer Completed" << std::endl;
return;
}
【问题讨论】:
-
你正在做的是一种叫做“
printf调试”的东西,一般不推荐。您将需要使用实际的调试器。另外,请在每个制表符级别缩进一个以上的空格。这简直是无法阅读…… -
@rlbond 我所做的几乎所有调试都是“printf 调试”——实践绝对没有错。
-
Printf 调试非常适合找出一般故障区域,但对于细节,调试器提供的帮助更多。
-
第二个:有时使用 printf 会容易得多。
-
@peachy 细节方面,我倾向于靠思考。