gpt4 book ai didi

C++ - 调用 std::vector 的 .clear() 时发生访问冲突

转载 作者:行者123 更新时间:2023-11-28 05:52:03 27 4
gpt4 key购买 nike

我正在 Visual Studio C++ MFC 应用程序中实现 XLSX 电子表格阅读器,并且在多次执行时遇到访问冲突错误:

First-chance exception at 0x7720e39e in VCT.exe: 0xC0000005: Access violation reading location 0x02bdddab.
Unhandled exception at 0x7720e39e in VCT.exe: 0xC0000005: Access violation reading location 0x02bdddab.
The program '[1756] VCT.exe: Native' has exited with code -1073741819 (0xc0000005).

奇怪的是,根据我的其余代码,这可能发生在函数被调用两次、三次或更多次之后……这让我认为它与时间有关,但我只让单线程运行。我的另一个(更现实的)假设是它是一种未定义的行为。这使得调试特别困难。让我感到困惑的是为什么在多次调用该函数后会发生这种访问冲突。

添加到问题:

每次单击按钮时,我都会调用函数 getVectorAllIP。单击几下(调用 getVectorAllIP)后,我在第一次调用 mm_XLSXReader.xlsxGetCellOffset 时收到访问冲突错误。

vector<CString> CVCTDlg::getVectorAllIP(string ipName){

CString CSIP1;

vector<CString> VCSIPAddresses;

XLSXReader mm_XLSXReader;
mm_XLSXReader.reloadFile();
mm_XLSXReader.setFilePath(XLSX_FILE_PATH);

for(int i = 0; i < m_vectorStrHostname.size(); i++)
{
CSIP1="";
for(int iOffset = 0; iOffset < 4; iOffset++)
{

CSIP1.Append(mm_XLSXReader.xlsxGetCellOffset(ipName, i, iOffset).c_str());
if(iOffset != 3)
{
CSIP1.Append(".");
}
}

if(CSIP1 != "...")
{

VCSIPAddresses.push_back(CSIP1);

}else{
VCSIPAddresses.push_back("");
}

}

return VCSIPAddresses;

}

xlsxGetCellOffset 中,访问冲突错误发生在 readSheetXml 中。

string XLSXReader::xlsxGetCellOffset(string columnName, int id, int offset)
{
string contentToReturn;
id++;

if(!m_bFileInMemory)
{
if(openm_XLSXReader())
{
readSharedStringsXml();
readSheetXml();

closem_XLSXReaders();

m_bFileInMemory = true;
}
}

for(int i = 0; i < m_header.size(); i++)
{
if(m_header.at(i) == columnName && m_header.size() > i + offset)
{
if(m_sheetContent.size() > id)
{
if(m_sheetContent.at(id).size() > i)
{
contentToReturn = m_sheetContent.at(id).at(i+offset);
}
}
}
}

return contentToReturn;
}

访问冲突发生在最后的清除序列中。特别是在 columnContent.clear() 处。如果我删除 columnContent.clear(),它会出现在下一行 tParameterColumn.clear()

void XLSXReader::readSheetXml()
{
if(m_m_XLSXReader)
{
int error = unzLocateFile(m_m_XLSXReader, SHEET_NAME, 0);
if(error == UNZ_OK)
{
error = unzOpenCurrentFile(m_m_XLSXReader);
if(error == UNZ_OK)
{
int readingStatus = 0;
char readBuffer[BUFFERSIZE];
string file;
int indexValue;
//Reading File
do
{
readingStatus = unzReadCurrentFile(m_m_XLSXReader, readBuffer, BUFFERSIZE);
file.append(readBuffer, readingStatus);
}while(readingStatus > 0);


//Sort Data
vector<string> rowContent;
rowContent = findXmlTagsContent(file, "row");

unsigned int iHdrSize;
m_header.clear();

vector<string> columnContent;
vector<string> tParameterColumn;
vector<string> rParameterColumn;
vector<string> tmpRow;
for(int i = 0 ; i < rowContent.size(); i++)
{

columnContent=findXmlTagsContent( rowContent.at(i), "c");
rParameterColumn=findXmlParameterInTag(rowContent.at(i), "c", "r");
tParameterColumn=findXmlParameterInTag(rowContent.at(i), "c", "t");
if(i==0){
iHdrSize = columnContent.size();
}

//Should be equal
if(columnContent.size() == tParameterColumn.size())
{
unsigned int iFilledColumns = 0;
for(int j = 0 ; j < columnContent.size(); j++)
{

int columnNumber = 0;

if(!rParameterColumn.at(j).empty())
{
columnNumber = columnLetter2Int(rParameterColumn.at(j));
}

vector<string> value;
value = findXmlTagsContent(columnContent.at(j), "v");

if(value.size()>1){
value.clear();
value.push_back("");
}

//Header Reading
if( i == 0)
{
//Fill empty spaces in excel sheet with ""
for(int a = 1; a < columnNumber-iFilledColumns; a++)
{
m_header.push_back("");
}
iFilledColumns=m_header.size();

//link to sharedString
if(tParameterColumn.at(j) == "s")
{
indexValue = atoi(value.at(0).c_str());
string tmpStr = m_sharedString.at(indexValue);
m_header.push_back(tmpStr);
}
//Value
else
{
m_header.push_back(value.at(0));
}
}
// Content Reading
else
{
////Fill empty spaces in excel sheet with ""
for(int a = 1; a < columnNumber-iFilledColumns; a++)
{
tmpRow.push_back("");
}
iFilledColumns=tmpRow.size();
//link to sharedString

if(tParameterColumn.at(j) == "s")
{
indexValue = atoi(value.at(0).c_str());
tmpRow.push_back(m_sharedString.at(indexValue));
}
//Value
else
{
if(value.size() != 0)
{
tmpRow.push_back(value.at(value.size()-1));
}
else
{
tmpRow.push_back("");
}
}

}
iFilledColumns++;
}
for(int k=0;k<iHdrSize-iFilledColumns;k++){
tmpRow.push_back("");
}
m_sheetContent.push_back(tmpRow);
tmpRow.clear();
columnContent.clear();
tParameterColumn.clear();
rParameterColumn.clear();

}
}
}
}
}
}

仅供引用,m_m_XLSXReader 是在 xlsxGetCellOffset 中调用 openm_XLSXReader 时实例化的。供您引用:

bool XLSXReader::openm_XLSXReader()
{
//Uncompress .xlsx
m_m_XLSXReader = unzOpen(m_strXLSXPath.c_str());

if(m_m_XLSXReader){
return true;
}
return false;
}

希望有人能指出一些明显的明显错误,因为我开始质疑我的理智 :) 谢谢。

最佳答案

这个循环:

do
{
readingStatus = unzReadCurrentFile(m_m_XLSXReader, readBuffer, BUFFERSIZE);
file.append(readBuffer, readingStatus);
} while (readingStatus > 0);

将附加最后一个读取 block 两次,很可能会产生无效的 XML。我不知道您使用哪个库来读取 XML(除了这个问题之外,找不到对 findXmlTagsContent 的任何引用),以及它的弹性如何,但怀疑它在被喂食垃圾时可能表现不佳.另外,您没有检查任何可能的错误...

底线是:尝试像这样阅读您的文件:

while ((readingStatus = unzReadCurrentFile(m_m_XLSXReader, readBuffer, BUFFERSIZE)) > 0)
file.append(readBuffer, readingStatus);

另外,如果返回为负数(错误代码),你打算怎么办?

关于C++ - 调用 std::vector 的 .clear() 时发生访问冲突,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35022941/

27 4 0
文章推荐: c++ - XBee DigiMesh 帧中的奇怪位和错误的校验和
文章推荐: javascript - 修复弹出框并使背景滚动
文章推荐: c++ - 获取当前桌面壁纸的路径
文章推荐: jquery - 在可扩展