ERRORE "Control reaches end of non void function"

di il
3 risposte

ERRORE "Control reaches end of non void function"

Salve a tutti,
un mio amico mi ha passato questo codice C che lui riesce a far girare correttamente mentre il mio compilatore puntualmente mi restituisce l'errore "Control reaches end of non void function".
Vi posto il codice certo che la vostra esperienza mi potrà aiutare:

Grazie in anticipo

#include <stdio.h>
#include <stdlib.h>
#include <math.h>
float m;
float b;
float S;
float c;
float TW;
float CD0;
float Mdr;
float k;
float z;
int RS;
float JX,JY,JZ,JXZ;
int delta_e,delta_a,delta_r,beta;
float p,T,ro;
float ro_0=1.225;
int T_0=288;
int p_0=101320;
int p_t=22632;
int R=287;
float g=9.81;
float T_t=216.5;
// Funzione 1 - Lettura da file .dat
// Devo saltare 3 righe, e poi leggere i valori contenuti,
// inserendoli nelle giuste variabili globali

int leggiFileDat(char* nomeFile) {
FILE* fIn;
fIn = fopen(nomeFile, "r"); // r = read, così non possiamo proprio modificarlo

// L'assunzione è che il file sia di testo (non binario)
// Le prime 3 righe si possano saltare:
char *line = NULL;
size_t linecap = 0;

getline(&line, &linecap, fIn);
getline(&line, &linecap, fIn);
getline(&line, &linecap, fIn);

// ora ho saltato (leggendole) 3 righe
// perciò inizio a popolare le mie variabili globali

fscanf(fIn, "%f", &m);
getline(&line, &linecap, fIn);
fscanf(fIn, "%f", &b);
getline(&line, &linecap, fIn);
fscanf(fIn, "%f", &S);
getline(&line, &linecap, fIn);
fscanf(fIn, "%f", &c);
getline(&line, &linecap, fIn);
fscanf(fIn, "%f", &TW);
getline(&line, &linecap, fIn);
fscanf(fIn, "%f", &CD0);
getline(&line, &linecap, fIn);
fscanf(fIn, "%f", &Mdr);
getline(&line, &linecap, fIn);
fscanf(fIn, "%f", &k);
getline(&line, &linecap, fIn);
fscanf(fIn, "%f", &z);
getline(&line, &linecap, fIn);
getline(&line, &linecap, fIn);
fscanf(fIn, "%d", &RS);
getline(&line, &linecap, fIn);
fscanf(fIn, "%f", &JX);
getline(&line, &linecap, fIn);
fscanf(fIn, "%f", &JY);
getline(&line, &linecap, fIn);
fscanf(fIn, "%f", &JZ);
getline(&line, &linecap, fIn);
fscanf(fIn, "%f", &JXZ);
getline(&line, &linecap, fIn);
getline(&line, &linecap, fIn);
getline(&line, &linecap, fIn);
getline(&line, &linecap, fIn);
fscanf(fIn, "%d", &delta_e);
getline(&line, &linecap, fIn);
fscanf(fIn, "%d", &delta_a);
getline(&line, &linecap, fIn);
fscanf(fIn, "%d", &delta_r);
getline(&line, &linecap, fIn);
getline(&line, &linecap, fIn);
getline(&line, &linecap, fIn);
fscanf(fIn, "%d", &beta);
// stampiamo a schermo solo per vedere se ha letto correttamente

printf("[%.3f] [%.3f] [%.3f] [%.3f] [%.3f] [%.3f] [%.3f] [%.3f] [%.3f] [%d] [%.3f] [%.3f] [%.3f] [%.3f] [%d] [%d] [%d] [%d]\n ", m, b, S, c, TW, CD0, Mdr, k, z, RS, JX, JY, JZ, JXZ, delta_e, delta_a, delta_r, beta);
fclose(fIn);
}

// Funzione 2 - Routine per l'atmosfera
float pressione(float p){
if (z<=11000)
return p=p_0*pow((1-(0.0065*z)/T_0),(g/(0.0065*R)));
else
return p=p_t*exp((-g/(R*T_t))*(z-11000));
}
float temperatura(float T){
if (z<=11000)
return T=T_0-0.0065*z;
else
return T=T_t;
}
/*
*
*/
int main(int argc, char** argv) {
leggiFileDat("ef16.dat");
printf("%f %f\n",pressione(p), temperatura(T));
ro=pressione(p)/(R*temperatura(T));
printf("%f",ro);
return (EXIT_SUCCESS);
}

3 Risposte

Devi accedere o registrarti per scrivere nel forum
3 risposte