在此函数中未初始化使用[-Wuninitialized]

时间:2019-05-24 03:12:51

标签: c++ compiler-errors

我正在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即可编译

已经做了几个小时,变得非常绝望,甚至不知道即时消息是否提供了必要的信息,如果您需要任何信息,请让我知道并且对此进行修改,谢谢。

1 个答案:

答案 0 :(得分:1)

这是问题所在:

BlocoMemoria *ram = gerarBM(ram, tamanhoRam);

您在定义它的同一条语句的右侧使用ram

相反,您可以这样更改gerarBM

BlocoMemoria* gerarBM(int q){
    return new BlocoMemoria[q];
}

并这样称呼它:

BlocoMemoria* ram = gerarBM(tamanhoRam);