0
我正在編寫一個模擬緩存的程序。我使用QVector作爲結構。我有一個QVent的QVector。然而,當我嘗試編輯整數,它會導致運行時錯誤:如何編輯Qvector內Qvector的內容
*** glibc detected *** ./CompOrgProject3: free(): invalid next size (fast): 0x00000000010d2550 ***
======= Backtrace: =========
/lib/x86_64-linux-gnu/libc.so.6(+0x7eb96)[0x7fd31b469b96]
./CompOrgProject3[0x402558]
./CompOrgProject3[0x402bf3]
./CompOrgProject3[0x402005]
/lib/x86_64-linux-gnu/libc.so.6(__libc_start_main+0xed)[0x7fd31b40c76d]
./CompOrgProject3[0x4023c1]
======= Memory map: ========
00400000-00405000 r-xp 00000000 08:01 404625 /home/**/Documents/CompOrgProject3/CompOrgProject3
00604000-00605000 r--p 00004000 08:01 404625 /home/**/Documents/CompOrgProject3/CompOrgProject3
00605000-00606000 rw-p 00005000 08:01 404625 /home/**/Documents/CompOrgProject3/CompOrgProject3
010cb000-010ec000 rw-p 00000000 00:00 0
這裏是一個正在運行的鱈魚: 主:
#include <fstream>
#include <QStringList>
#include <iostream>
#include <QFile>
#include <QTextStream>
#include <QDebug>
#include <cstdlib>
#include <string>
#include "cache.h"
using namespace std;
int main()
{
QFile instFile;
instFile.setFileName("test.trace");
int cacheSizes[4] = {1024, 4096, 16384, 65536};
int blockSizes[4] = {8, 16, 32, 64};
QString types[4] = {"DM", "2W", "4W" , "FA"};
if(!instFile.open(QIODevice::ReadOnly))
{
return -1;
}
QTextStream in(&instFile);
QStringList instList;
while(!in.atEnd())
{
QString temp;
temp = in.readLine();
instList.append(temp);
}
for(int i = 0; i < instList.size(); i++)
{
cout << instList.at(i).toStdString() << "\n";
}
for(int i = 0; i < 4; i++)
{
for(int j = 0; j < 4; j++)
{
for(int k = 0; k < 4; k++)
{
Cache c(cacheSizes[i], blockSizes[j], types[k], instList);
c.simulateCache();
}
}
}
return 0;
}
這是模擬功能,我有QVectors:
void Cache::simulateCache()
{
if(this->instList.size() < 1)
{
screenOut << "Cannot simulate cache: there are no instructions";
}
else
{
screenOut << "Starting simulation...\n";
int entry_per_block = block_size/4;
block_count = cache_size/block_size;
QVector<QVector<int> > ca(block_count);
for(int i = 0; i < block_count; i++)
{
ca[i].resize(entry_per_block);
}
screenOut << "QVector created.\n";
for(int i = 0; i < this->instList.size(); i++)
{
QStringList inst_parts = instList.at(i).split(QRegExp(" "));
QString instType = inst_parts.at(0);
int mem_addr = inst_parts.at(1).toInt(0, 16);
if(this->type.compare("DM") == 0)
{
int block_index = (int) (mem_addr/block_size) % block_count;
int block_offset = mem_addr % block_size;
if(ca.at(block_index).at(block_offset) == mem_addr)
{
this->hits++;
if(instType.compare("W") == 0)
{
this->cacheToMem+=block_size;
}
}
else
{
this->misses++;
this->memToCache += block_size;
ca[block_index][block_offset] = mem_addr;
if(instType.compare("W") == 0)
{
this->cacheToMem+=block_size;
}
for(int i = block_offset - 1; i >= 0; i--)
{
//ca[block_index][i] = mem_addr - ((block_offset - i) * 4);
//ca[block_index].insert(i, mem_addr - ((block_offset - i) * 4));
}
for(int i = block_offset + 1; i < entry_per_block; i++)
{
//ca[block_index][i] = mem_addr + ((i - block_offset) * 4));
//ca[block_index].insert(i, mem_addr + ((i - block_offset) * 4));
}
}
}
}
hit_rate = hits/instList.size();
screenOut << hit_rate << "\n";
}
}
這是導致錯誤的路線,我相信:
ca[block_index][block_offset] = mem_addr;
乍一看我猜想中的一個索引超出範圍。 – 2013-05-08 20:59:09
在函數的開頭,我調整了qvectors的大小以適合所有可能的索引。還是不行? – Amre 2013-05-08 21:01:16
嘗試使用valgrind和gdb:sudo valgrind --attach-db = yes ./CompOrgProject3,這將允許您在內存錯誤時進行調試 – 2013-05-08 21:04:42