Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre
L'abbonamento Ultimate di GeForce NOW ora comprende la nuova architettura Blackwell RTX con GPU RTX 5080 che garantisce prestazioni tre volte superiori alla precedente generazione. Non si tratta solo di velocità, ma di un'esperienza di gioco migliorata con nuove tecnologie di streaming e un catalogo giochi raddoppiato grazie alla funzione Install-to-Play
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco
Deebot X11 Omnicyclone implementa tutte le ultime tecnologie Ecovacs per l'aspirazione dei pavimenti di casa e il loro lavaggio, con una novità: nella base di ricarica non c'è più il sacchetto di raccolta dello sporco, sostituito da un aspirapolvere ciclonico che accumula tutto in un contenitore rigido
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio
Grazie ad un mocio rotante che viene costantemente bagnato e pulito, Narwal Flow assicura un completo e capillare lavaggio dei pavimenti di casa. La logica di intellignza artificiale integrata guida nella pulizia tra i diversi locali, sfruttando un motore di aspirazione molto potente e un sistema basculante per la spazzola molto efficace sui tappeti di casa
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 16-06-2008, 14:45   #1
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
[C] Passaggio puntatore e realloc in funzione

Salve a tutti
avrei un piccolo problema nel realizzare una funzione. Il mio obiettivo è leggere un file di dimensioni non note. Per fare questo volevo realizzare una funzione che riceve in ingresso un puntatore e all'interno della funzione viene cambiata la dimensione del puntatore per memorizzare tutti i dati. Il problema è che facendo in questo modo all'esterno della funzione non riesco a vedere i dati corretti. La forma del funzione che vorrei è questa:
Codice:
int lettura(int *numeri)
{
    ....
    numbers = (int*) realloc (numbers, count * sizeof(int));
    ...
}

int main()
{
    int * numbers = NULL;
    ...
    leggi(numbers)
    ....
}
In un thread precedente avevano provato ad illuminarmi ma non mi è chiaro come si aggiorna il puntatore. Qualcuno di buona fede potrebbe spiegarmelo in parole semplici?
Grazie
__________________
"May the wind always be at your back and the sun upon your face.
And may the wings of destiny carry you aloft to dance with the stars...."
salvodel è offline   Rispondi citando il messaggio o parte di esso
Old 16-06-2008, 15:05   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2774
Devi usare un puntatore a puntatore:

Codice:
int lettura(int **numeri)
{
    ....
    *numeri = (int*) realloc (*numeri, count * sizeof(int));
    ...
}

int main()
{
    int **numbers = (int**) malloc (sizeof(int*));
    ...
    leggi(numbers)
    ....
}
Spero di aver messo giusti tutti gli asterischi... prova!
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 16-06-2008, 15:08   #3
khelidan1980
Senior Member
 
L'Avatar di khelidan1980
 
Iscritto dal: Mar 2005
Città: Morimondo city
Messaggi: 5491
ma guarda che se leggi con fopen ed fread mica devi sapere la dimensione del file!

Non ho mica capito che devi fare mi sa......
__________________
Khelidan
khelidan1980 è offline   Rispondi citando il messaggio o parte di esso
Old 16-06-2008, 15:19   #4
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
Provo a postare quello che ho scritto con i suggerimenti:
Codice:
int legge_turb(float **time, float **dati, float tMAX, float dati_medio)
{
	FILE *fdati;
	int count;

	count=0;
	if((fdati=fopen("turb.dat","r"))==NULL)
		printf("Impossibile aprire il file");
	else
	{
		printf("Lettura dati in corso\n");
		if(count==0)
		{
			/*Leggo la prima riga*/
			fscanf(fdati,"%f",&tMAX);
			fscanf(fdati,"%f",&dati_medio);
		}
		while(fscanf(fdati,"%f",&time[count])>0)qui è sicuramente sbagliato
		{
			fscanf(fdati,"%f",&dati[count]);
			count++;
			*time = (float*) realloc (*time, (count+1)*sizeof(float));
			*dati = (float*) realloc (*dati, (count+1)*sizeof(float));
		}
	}
	return 1;
}
Fuori dalla funzione come l'aggiorno?
Grazie
__________________
"May the wind always be at your back and the sun upon your face.
And may the wings of destiny carry you aloft to dance with the stars...."
salvodel è offline   Rispondi citando il messaggio o parte di esso
Old 16-06-2008, 17:30   #5
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2774
Potresti spiegare cosa deve fare questa funzione? E come è strutturato il file che stai leggendo?

Codice:
int legge_turb(float **time, float **dati, float tMAX, float dati_medio)
{
	FILE *fdati;
	int count;

	count=0;
	if((fdati=fopen("turb.dat","r"))==NULL)
		printf("Impossibile aprire il file");
	else
	{
		printf("Lettura dati in corso\n");
		if(count==0) //count sarà sicuramente uguale a zero, perché l'if?
		{
			/*Leggo la prima riga*/
			fscanf(fdati,"%f",&tMAX);
			fscanf(fdati,"%f",&dati_medio);
		}
		while(fscanf(fdati,"%f",&time[count])>0) //Senza & dovrebbe compilare
		{
			fscanf(fdati,"%f",&dati[count]);//Anche qui devi togliere l'&
			count++;
			*time = (float*) realloc (*time, (count+1)*sizeof(float));
			*dati = (float*) realloc (*dati, (count+1)*sizeof(float));
		}
	}
	return 1; //Ritorni 1 sia se abbia avuto successo che non, sicuro che sia corretto?
}
Queste sono correzioni al volo ma non so neanche cosa debba fare la funzione, quindi non ti so dire se questo basta.
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 17-06-2008, 10:02   #6
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Potresti spiegare cosa deve fare questa funzione? E come è strutturato il file che stai leggendo?

Queste sono correzioni al volo ma non so neanche cosa debba fare la funzione, quindi non ti so dire se questo basta.
Prima di tutto grazie mille per l'aiuto.
La funzione deve leggere un file .dat di due colonne per un numero di righe non noto. Puoi trascurare quell'if perché è ridondante in effetti poiché cosi facendo legge sicuramente la prima riga. Quello che mi importa è che in time e dati metta la prima e la seconda colonna di dati. Questo funziona se faccio tutto nel main ma se passo i puntatori alla funzione e poi rialloco no. Da quello che ho capito dovrei tenere aggiornati i puntatori ma non mi è chiaro come. Cionci aveva provato a spiegarmelo nel thread che ho linkato ma non mi è chiaro. Ho solo un manuale di C in biblio e non è che ci sia molto quindi se riuscite a darmi una mano ve ne sarei grato.
Cmq ho provato a togliere quegli & di tropo e non va. Ottengo:
Unhandled exception at 0x00412519 in programma.exe: 0xC0000005: Access violation reading location 0x00000000.
in
Codice:
while(fscanf(fdati,"%f",time[count])>0)
Grazie
__________________
"May the wind always be at your back and the sun upon your face.
And may the wings of destiny carry you aloft to dance with the stars...."
salvodel è offline   Rispondi citando il messaggio o parte di esso
Old 17-06-2008, 14:04   #7
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2774
Perche' stai tentando di accedere (tra l'altro in scrittura) ad un'area di memoria che non hai ancora allocato. Il primo realloc lo dovresti fare prima del while
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 17-06-2008, 15:58   #8
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Perche' stai tentando di accedere (tra l'altro in scrittura) ad un'area di memoria che non hai ancora allocato. Il primo realloc lo dovresti fare prima del while
Il problema è che io faccio un malloc fuori dalla funzione e poi passo quello. Sto provando tutte le cose piu stane che mi passano per la testa:
nel main
Codice:
time =(float **)malloc(1*sizeof(float*));
dati =(float **)malloc(1*sizeof(float*));
Codice:
int legge_turb(float **time, float **dati, float tMAX, float dati_medio)
{
	......
	while(fscanf(fdati,"%f",time[count])>0)
	{
	fscanf(fdati,"%f",dati[count]);
	count++;
	*time = (float*) realloc (*time, (count+1)*sizeof(float));
	*dati = (float*) realloc (*dati, (count+1)*sizeof(float));
	}
}
Sto cercando su internet esempi per capire meglio il funzionamento...ma niente. Aspetto suggerimenti. Grazie.
__________________
"May the wind always be at your back and the sun upon your face.
And may the wings of destiny carry you aloft to dance with the stars...."
salvodel è offline   Rispondi citando il messaggio o parte di esso
Old 17-06-2008, 19:59   #9
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2774
Quote:
Originariamente inviato da salvodel Guarda i messaggi
Il problema è che io faccio un malloc fuori dalla funzione e poi passo quello. Sto provando tutte le cose piu stane che mi passano per la testa:
nel main
Codice:
time =(float **)malloc(1*sizeof(float*));
dati =(float **)malloc(1*sizeof(float*));
Allora, con questo hai allocato lo spazio per due puntatori a float (o ad un array di float), e va bene, tuttavia non è stato ancora allocato alcun array, io ti sconsiglio di farlo nel main, è meglio che a questo ci pensi la funzione che legge il file.

Mi sono anche accorto che volendoti spiegare nel dettaglio come funzionano le cose ti ho fatto scrivere un codice un po' confusionario, almeno nel main, riprendendo il primo esempio che ti ho fatto, avevo scritto:
Codice:
int lettura(int **numeri)
{
    ....
    *numeri = (int*) realloc (*numeri, count * sizeof(int));
    ...
}

int main()
{
    int **numbers = (int**) malloc (sizeof(int*));
    ...
    leggi(numbers)
    ....
}
Ma questo è equivalente a:
Codice:
int lettura(int **numeri)
{
    ....
    *numeri = (int*) realloc (*numeri, count * sizeof(int));
    ...
}

int main()
{
    int *numbers;
    ...
    leggi(&numbers)
    ....
}
Io preferisco questa, se non altro perché alla fine non devo fare una free per liberare il puntatore.

Quote:
Codice:
int legge_turb(float **time, float **dati, float tMAX, float dati_medio)
{
	......
	while(fscanf(fdati,"%f",time[count])>0)
	{
	fscanf(fdati,"%f",dati[count]);
	count++;
	*time = (float*) realloc (*time, (count+1)*sizeof(float));
	*dati = (float*) realloc (*dati, (count+1)*sizeof(float));
	}
}
Sto cercando su internet esempi per capire meglio il funzionamento...ma niente. Aspetto suggerimenti. Grazie.
Dunque questo codice diventa:
Codice:
int legge_turb(float **time, float **dati, float tMAX, float dati_medio)
{
	......
	while(!feof(fdati))
	{
	   *time = (float*) realloc (*time, (count+1)*sizeof(float));
	   *dati = (float*) realloc (*dati, (count+1)*sizeof(float));
	   fscanf(fdati,"%f",time[count])
	   fscanf(fdati,"%f",dati[count]);
	   count++;
	}
}
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2008, 12:10   #10
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
Qui ho riassunto un po quello che mi hai detto. Spero di non aver fatto un mix di !!
Codice:
#include <stdlib.h>
#include <stdio.h>

int legge(float **dati);

int main()
{
	int i;
	float *dati;

	legge(&dati);
	
	for(i=0;i<20;i++)
		printf("%f\n",dati[i]);
		
	return 1;
}
	

int legge(float **dati)
{
	FILE *fdati;
	int count=0;
	fdati=fopen("dati.dat","r");
	while(!feof(fdati))
	{
	   *dati = (float*) realloc (*dati, (count+1)*sizeof(float));
	   fscanf(fdati,"%f",dati[count]);
	   count++;
	}
}
Se non sei al mare e il cervello non si è sciolto come il mio con l'afa, potresti dargli un'occhaita?
Grazie
__________________
"May the wind always be at your back and the sun upon your face.
And may the wings of destiny carry you aloft to dance with the stars...."
salvodel è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2008, 13:17   #11
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2774
Purtroppo sono a casa e mi sto sciogliendo lo stesso...
Abbiamo fatto un po' di errori tutti e due (scusa), ti posto il sorgente corretto:
Codice:
#include <stdlib.h>
#include <stdio.h>

int legge(float **dati);

int main()
{
	int i;
	float *dati=NULL; //Va inizializzato a NULL per non mandare in tilt la realloc (in alternativa puoi fare una malloc prima delle realloc), errore mio

	legge(&dati);

	for(i=0;i<20;i++)
		printf("%f\n",dati[i]);
	free(dati); //Ricordati di liberare la memoria quando hai finito

	return 1;
}


int legge(float **dati)
{
	FILE *fdati;
	float *temp;
	int count=0;
	fdati=fopen("dati.dat","r");
	if(!fdati){  //Controlliamo l'esito dell'apertura
            printf("Errore nell'apertura del file\n");
            return 0;
        }
	while(!feof(fdati))
	{
	   temp = (float*) realloc (*dati, (count+1)*sizeof(float));//Errore mio, bisognerebbe sempre controllare l'esito delle operazioni (per questo ho aggiunto la variabile temp)
	   if(!temp){
	        printf("Errore nella riallocazione\n");
            return 0;
       }
	   *dati=temp;
	   fscanf(fdati,"%f",*dati+count); //Errore mio
	   count++;
	}
	fclose(fdati); //Ricordati di chiudere il file
	return 1;
}
Ora dovrebbe essere tutto ok
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 21-06-2008, 16:35   #12
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Purtroppo sono a casa e mi sto sciogliendo lo stesso...
Abbiamo fatto un po' di errori tutti e due (scusa), ti posto il sorgente corretto:
Ora dovrebbe essere tutto ok
Perfetto! Grazie anche per i vari suppellettili! Non li avevo messi semplicemente per tagliare corto sul passaggio del puntatore.
Di nuovo grazie mille. Ora me lo confeziono per bene per tutti i programmini in cui mi serve aprire un file dati. Spero di non avere ulteriori problemi.
Ciao
__________________
"May the wind always be at your back and the sun upon your face.
And may the wings of destiny carry you aloft to dance with the stars...."
salvodel è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Prova GeForce NOW upgrade Blackwell: il cloud gaming cambia per sempre Prova GeForce NOW upgrade Blackwell: il cloud ga...
Ecovacs Deebot X11 Omnicyclone: niente più sacchetto per lo sporco Ecovacs Deebot X11 Omnicyclone: niente più...
Narwal Flow: con il mocio orizzontale lava i pavimenti al meglio Narwal Flow: con il mocio orizzontale lava i pav...
Panasonic 55Z95BEG cala gli assi: pannello Tandem e audio senza compromessi Panasonic 55Z95BEG cala gli assi: pannello Tande...
HONOR Magic V5: il pieghevole ultra sottile e completo! La recensione HONOR Magic V5: il pieghevole ultra sottile e co...
Larry Ellison guadagna 101 miliardi in u...
Johnson Controls amplia la gamma di solu...
NASA Perseverance: il rover potrebbe ave...
Quelli di Immuni si 'pappano' Vimeo: Ben...
Changan lancia la Deepal S05 in Europa, ...
Substrati in vetro, Intel smentisce le v...
ECOVACS DEEBOT T50 PRO OMNI Gen2 fa piaz...
Windelo 62: catamarano a vela che unisce...
Francia, in arrivo un incentivo di 1.000...
Haier, la sorpresa a IFA: la lavatrice C...
GeForce RTX 5000 SUPER in arrivo? Sembra...
Ionity prova una soluzione contro i ladr...
Pirateria, svolta clamorosa: Dazn e Lega...
Maxi richiamo Toyota e Lexus: oltre 900....
Blackwell Ultra: fino al 45% di prestazi...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 04:12.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
Served by www3v