我正在C ++上进行内存缓存模拟,经过大量编码后出现此错误:
g++ main.cpp blocoMemoria.cpp endereco.cpp instrucao.cpp mmu.cpp maquina.cpp -o joubert.o -g -Wall
main.cpp: In function ‘int main(int, const char**)’:
main.cpp:18:29: warning: ‘ram’ is used uninitialized in this function [-Wuninitialized]
BlocoMemoria *ram = gerarBM(ram, tamanhoRam);
~~~~~~~^~~~~~~~~~~~~~~~~
main.cpp:19:32: warning: ‘cache1’ is used uninitialized in this function [-Wuninitialized]
BlocoMemoria *cache1 = gerarBM(cache1, tamanhoCache1);
~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~
main.cpp:20:32: warning: ‘cache2’ is used uninitialized in this function [-Wuninitialized]
BlocoMemoria *cache2 = gerarBM(cache2, tamanhoCache2);
~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~
main.cpp:26:66: warning: ‘memoriaInstrucoes’ is used uninitialized in this function [-Wuninitialized]
Instrucao *memoriaInstrucoes = montarInstrucoesProgramaAleatorio(memoriaInstrucoes, tamanhoPrograma, qdePalavrasBloco, tamanhoRam);
这是我的主要爱好
#include <iostream>
#include <bits/stdc++.h>
#include "endereco.hpp"
#include "instrucao.hpp"
#include "blocoMemoria.hpp"
#include "mmu.hpp"
#include "maquina.hpp"
using namespace std;
int main(int argc, char const *argv[]){
int tamanhoRam= 1000;
int tamanhoCache1 = 8;
int tamanhoCache2 = 16;
int tamanhoPrograma = 1000;
int qdePalavrasBloco = 4;
BlocoMemoria *ram = gerarBM(ram, tamanhoRam);
BlocoMemoria *cache1 = gerarBM(cache1, tamanhoCache1);
BlocoMemoria *cache2 = gerarBM(cache2, tamanhoCache2);
montarRam(ram, tamanhoRam, qdePalavrasBloco);
montarCacheVazia(tamanhoCache1, cache1);
montarCacheVazia(tamanhoCache2, cache2);
Instrucao *memoriaInstrucoes = montarInstrucoesProgramaAleatorio(memoriaInstrucoes, tamanhoPrograma, qdePalavrasBloco, tamanhoRam);
maquina(memoriaInstrucoes, ram, cache1, cache2);
deleteBM(cache2);
deleteBM(cache1);
deleteBM(ram);
deleteInst(memoriaInstrucoes);
cout<<"terminou\n";
return 0;
}
这是我的blocoMemoria.cpp:
#include "blocoMemoria.hpp"
using namespace std;
struct blocoMemoria{
int *palavras = new int[4];
int endBloco = -1;
bool atualizado = false;
int custo = 0;
int cacheHit = 0;
};
BlocoMemoria* gerarBM(BlocoMemoria* b, int q){
b=new BlocoMemoria[q];
return b;
}
BlocoMemoria *posToPoint(BlocoMemoria *z, int k){
BlocoMemoria *aux=&z[k];
return aux;
}
void deleteBM(BlocoMemoria *a){
delete a;
}
void juntarBM(BlocoMemoria *a, BlocoMemoria *b, int i){
if(i==1){
setPalavras(a, getPalavras(b));
setEndBloco(a, getEndBloco(b));
setAtualizado(a, isAtualizado(b));
setCusto(a, getCusto(b));
setCacheHit(a, getCacheHit(b));
}
else{
setPalavras(&a[i], getPalavras(b));
setEndBloco(&a[i], getEndBloco(b));
setAtualizado(&a[i], isAtualizado(b));
setCusto(&a[i], getCusto(b));
setCacheHit(&a[i], getCacheHit(b));
}
}
int getCusto(BlocoMemoria *c) {
return c->custo;
}
void setCusto(BlocoMemoria *c, int custo) {
c->custo = custo;
}
int* getPalavras(BlocoMemoria *c) {
return c->palavras;
}
int* getPalavras(BlocoMemoria *c, int i) {
return c[i].palavras;
}
void setPalavras(BlocoMemoria* c,int *palavras) {
c->palavras = palavras;
}
int getEndBloco(BlocoMemoria *c) {
return c->endBloco;
}
void setEndBloco(BlocoMemoria *c, int endBloco) {
c->endBloco = endBloco;
}
bool isAtualizado(BlocoMemoria *c) {
return c->atualizado;
}
void setAtualizado(BlocoMemoria *c) {
c->atualizado = !c->atualizado;
}
void setAtualizado(BlocoMemoria *c, bool d) {
c->atualizado = d;
}
int getCacheHit(BlocoMemoria *c) {
return c->cacheHit;
}
void setCacheHit(BlocoMemoria *c, int cacheHit) {
c->cacheHit = cacheHit;
}
我有点菜鸟,所以我不知道如果我在以下位置返回正确的指针,为什么会发生这种情况:
BlocoMemoria* gerarBM()
我试图只是在主要声明它们为 BlocoMemoria * ram = new BlocoMemoria []; 但是编译器不太喜欢。
我需要修复此问题的原因是因为在主程序执行中没有任何操作。
它无需-Wall即可编译
已经做了几个小时,变得非常绝望,甚至不知道即时消息是否提供了必要的信息,如果您需要任何信息,请让我知道并且对此进行修改,谢谢。
答案 0 :(得分:1)
这是问题所在:
BlocoMemoria *ram = gerarBM(ram, tamanhoRam);
您在定义它的同一条语句的右侧使用ram
。
相反,您可以这样更改gerarBM
:
BlocoMemoria* gerarBM(int q){
return new BlocoMemoria[q];
}
并这样称呼它:
BlocoMemoria* ram = gerarBM(tamanhoRam);