Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 27-02-2008, 11:11   #1
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
[C] realloc e funzione

Salve a tutti,
ho un dubbio su come funziona realloc. Il problema è che se utilizzo il seguente programma preso da cplusplus
Codice:
int main ()
{
  int input,n;
  int count=0;
  int * numbers = NULL;

  do {
     printf ("Enter an integer value (0 to end): ");
     scanf ("%d", &input);
     count++;
     numbers = (int*) realloc (numbers, count * sizeof(int));
     if (numbers==NULL)
       { puts ("Error (re)allocating memory"); exit (1); }
     numbers[count-1]=input;
  } while (input!=0);

  printf ("Numbers entered: ");
  for (n=0;n<count;n++) printf ("%d ",numbers[n]);
  free (numbers);

  return 0;
}
come una funzione non mi gira.
In sostanza dichiaro
Codice:
int * numbers = NULL;
nel main e poi lo passo alla funzione
Codice:
int lettura(int *numeri)
All'interno della funzione riesco a vedere il contenuto dell'array che mi crea ma appena esco perdo il contenuto. Ovviamente nella mia funzione non c'è il free(numbers). Mi sembra che il realloc crei un'allocazione solo all'interno della funzione. Possibile che sia cosi o sto facendo un altro errore?
Grazie a tutti.
__________________
"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 27-02-2008, 11:27   #2
gugoXX
Senior Member
 
L'Avatar di gugoXX
 
Iscritto dal: May 2004
Città: Londra (Torino)
Messaggi: 3692
E' possibile che tu abbia lasciato una dicharazione locale, nella funzione, di
int * numbers = NULL;

Ovvero, non e' che per caso la tua funzione sta agendo su un array locale, senza gestire quello che e' il tuo array esterno?

Come ragionevolmente ti aspetti, le Malloc, realloc, etc. sono funzioni globali. La loro allocazione non viene persa al di fuori del contesto in cui sono state chiamate.
__________________
Se pensi che il tuo codice sia troppo complesso da capire senza commenti, e' segno che molto probabilmente il tuo codice e' semplicemente mal scritto.
E se pensi di avere bisogno di un nuovo commento, significa che ti manca almeno un test.
gugoXX è offline   Rispondi citando il messaggio o parte di esso
Old 27-02-2008, 11:39   #3
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Attenzione ad usare realloc all'interno di una funzione eprché il puntatore ritornato da realloc può essere diverso da quello contenuto precedentemente in numbers.

Per tenere aggiornato numbers devi fare così:

Codice:
void f(int **numbers)
{
    .....
    *numbers = (int*) realloc (*numbers, count * sizeof(int));
}

int *num = (int *) calloc(10, sizeof(int));
f(&num);
oppure:
Codice:
int * f(int *numbers)
{
    .....
    numbers = (int*) realloc(numbers, count * sizeof(int));
    .....
    return numbers;
}

int *num = (int *) calloc(10, sizeof(int));
num = f(num);
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 27-02-2008, 13:33   #4
commodoro
Member
 
Iscritto dal: Jul 2007
Città: civitanova marche
Messaggi: 190
beh, credo che la seconda sia meglio in quanto a sintassi, cmq la dichiarazione di

Codice:
int *numbers=NULL
debba essere fatta globalmente se si utilizza realloc in una funzione
__________________
desktop: Intel Core 2Duo E6550 2,33GHz@4Mb cache, Asus P5N-E SLI, Nvidia 8500GT 512Mb, MAXTOR SATA 320GB + MAXTOR 80GB, Master DVD LG, Master CD HP, SO Kubuntu 7.10 e XP HE
commodoro è offline   Rispondi citando il messaggio o parte di esso
Old 27-02-2008, 14:49   #5
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
@cionci: il tuo codice non considera l'eventualità che realloc ritorni NULL.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 27-02-2008, 14:51   #6
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da 71104 Guarda i messaggi
@cionci: il tuo codice non considera l'eventualità che realloc ritorni NULL.
Infatti è solo un esempio...noti i puntini ? Inoltre il punto cruciale era il passaggio alla funzione, non l'allocazione
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 27-02-2008, 14:58   #7
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
Quote:
Originariamente inviato da cionci Guarda i messaggi
Infatti è solo un esempio...noti i puntini ?
li noto, ma il primo esempio causa comunque un leak in quell'evenienza.
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 27-02-2008, 15:09   #8
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da 71104 Guarda i messaggi
li noto, ma il primo esempio causa comunque un leak in quell'evenienza.
Non è detto...dipende da quello che metti nei puntini
Ad esempio avrei potuto fare questo:
Codice:
int *old = *numbers;
*numbers = (int*) realloc (*numbers, count * sizeof(int));
if(*numbers == NULL) free(old);
Che è anche più bello di fare:
Codice:
int *newnumbers =  (int*) realloc (*numbers, count * sizeof(int));
if(newnumbers == NULL)
{
   free(numbers);
   *numbers = NULL;
}
In ogni caso mi sembra superfluo preoccuparsi di un leak quando il 99% dei programmi deve abortire in caso che il valore di ritorno sia NULL, quella memoria verrà comunque liberata. Chiaramente se il programma non deve abortire si DEVE ad ogni costo preoccuparsi di questa evenienza, ma non è detto che si debba liberare la memoria.
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 27-02-2008, 16:53   #9
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
Quote:
Originariamente inviato da cionci Guarda i messaggi
Attenzione ad usare realloc all'interno di una funzione eprché il puntatore ritornato da realloc può essere diverso da quello contenuto precedentemente in numbers.

Per tenere aggiornato numbers devi fare così:
Grazie a tutti per le risposte. Cionci scusa ma non ho capito cosa devo fare per tenere aggiornato il puntatore e cosa significa.
Per adesso ho risolto cosi: nel main alloco la memoria di numbers per un solo elemento(sono sicuro che uno lo deve avere per forza)
Codice:
numbers=(int *)malloc(1*sizeof(int));
dopo di che utilizzo realloc solo nella function. In questo modo sembra funzionare.
Così è corretto oppure alcune volte potrebbe funzionare ed altre no?
Di nuovo grazie a tutti pewr i suggerimenti.
__________________
"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 27-02-2008, 17:34   #10
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Te l'ho scritto sopra quello che devi fare, realloc può ritornare un puntatore diverso e quindi devi aggiornare il puntatore anche al chiamante...
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 27-02-2008, 18:01   #11
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
Quote:
Originariamente inviato da cionci Guarda i messaggi
Te l'ho scritto sopra quello che devi fare, realloc può ritornare un puntatore diverso e quindi devi aggiornare il puntatore anche al chiamante...
Sinceramente non ho capito alcune cose tra cui perche fai una calloc di 10
Codice:
int *num = (int *) calloc(10, sizeof(int));
Cmq adesso cerco di capire la spiegazione che ha dato questo bravo ragazzo nel 2002. Lo conosci?
http://www.hwupgrade.it/forum/showthread.php?t=271054
__________________
"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 27-02-2008, 18:04   #12
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da salvodel Guarda i messaggi
Sinceramente non ho capito alcune cose tra cui perche fai una calloc di 10
Codice:
int *num = (int *) calloc(10, sizeof(int));
Era solo una prova Va bene con qualsiasi dimensione avesse prima
Quote:
Originariamente inviato da salvodel Guarda i messaggi
Cmq adesso cerco di capire la spiegazione che ha dato questo bravo ragazzo nel 2002. Lo conosci?
http://www.hwupgrade.it/forum/showthread.php?t=271054
Che tempi
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 27-02-2008, 18:48   #13
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
Quote:
Originariamente inviato da cionci Guarda i messaggi
Era solo una prova Va bene con qualsiasi dimensione avesse prima

Che tempi
Queste sono le due funzioni riscritte con i tuoi consigli
Codice:
int legge(struct mydata *data)

{

	FILE *fdati;
	double *tempread=NULL;
	int *vetcanali;
	int count, numcanali, punti;
	int t, j, i;

	sceltaING(&data, &vetcanali);

	punti=(int) data->INFO[10];
	numcanali=(int) data->INFO[0];

	count=0;
	tempread=(double *)malloc(1*sizeof(double));

	if((fdati=fopen(stringa,"r"))==NULL)

		printf("Impossibile aprire il file");

	else

	{

		printf("Lettura dati in corso\n");

		while(fscanf(fdati,"%le",&tempread[count])>0)

		{

			count++;
			tempread = (double*) realloc (tempread, (count+1)*sizeof(double));

		}

	}
	if((count/numcanali)>punti)
		count=punti;

	for(j=0;j<numcanali;j++)
	{
		printf("j=%d\n",j);
		printf("canale=%d\n",vetcanali[j]);
	}
	for(t=0;t<count;t++)
		for(j=0;j<numcanali;j++)
		{
			i=vetcanali[j]-1;
			//printf("i=%d\n",i);
			data->matrice[t][j]=tempread[i+t*numcanali];
		}


	fclose(fdati);
	free(tempread);

	printf("Lettura dati - O.K.\n");

	return count;

}
/****************************************************/
int sceltaING(struct mydata *data, int **canali)
{
    int ii,count,input;

    count=0;
    do {
        printf ("Enter an integer value (0 to end): ");
        scanf ("%d", &input);
        if(input!=0)
        {
            count++;
            printf("Ingresso diverso da 0.\n");
            *canali = (int*) realloc (*canali, count * sizeof(int));
            if (canali==NULL) {
                puts ("Error (re)allocating memory");
                exit (1);
            }
            canali[count-1]=input;   /*Qui mi da un warning*/
            printf("canali[%d]= %d\n",count-1,canali[count-1]);
        }
    } while (input!=0);
}
Il problema è che cosi mi si pianta dopo la prima assegnazione e mi da Segmentation fault (core dumped). Il warning dice assignment makes pointer from integer without a cast. Se riesci a buttargli una occhiata e a trovare l'errore sarebbe perfetto....non mi va di utilizzare quello mio che funziona ma che tu non hai trovato formalmente corretto.
Grazie e 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
Old 27-02-2008, 18:56   #14
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Chiaro, canali non la puoi utilizzare più così, ma devi utilizzarlo così:

(*canali)[i]

salvodel, non vorrei dirtelo, ma queste sono basi del C
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 27-02-2008, 19:08   #15
salvodel
Senior Member
 
L'Avatar di salvodel
 
Iscritto dal: Dec 2004
Messaggi: 783
Quote:
Originariamente inviato da cionci Guarda i messaggi
Chiaro, canali non la puoi utilizzare più così, ma devi utilizzarlo così:

(*canali)[i]

salvodel, non vorrei dirtelo, ma queste sono basi del C
Un po mi vergogno . Sto utilizzando il C con le basi di un solo esame. Il manuale che c'è in biblio è troppo "teorico" e non mi aiuta a risolvere questi casi. Ti ringrazio e chiedo scusa per il disturbo.
__________________
"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 27-02-2008, 19:56   #16
71104
Bannato
 
L'Avatar di 71104
 
Iscritto dal: Feb 2005
Città: Roma
Messaggi: 7029
Quote:
Originariamente inviato da cionci Guarda i messaggi
Non è detto...dipende da quello che metti nei puntini
Ad esempio avrei potuto fare questo:
Codice:
int *old = *numbers;
*numbers = (int*) realloc (*numbers, count * sizeof(int));
if(*numbers == NULL) free(old);
ENNO', perché i puntini nel primo esempio li hai messi solo prima della chiamata a realloc, non dopo


ok basta
71104 è offline   Rispondi citando il messaggio o parte di esso
Old 29-02-2008, 09:48   #17
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Quote:
Originariamente inviato da cionci Guarda i messaggi
Non è detto...dipende da quello che metti nei puntini
Ad esempio avrei potuto fare questo:
Codice:
int *old = *numbers;
*numbers = (int*) realloc (*numbers, count * sizeof(int));
if(*numbers == NULL) free(old);
Che è anche più bello di fare:
Codice:
int *newnumbers =  (int*) realloc (*numbers, count * sizeof(int));
if(newnumbers == NULL)
{
   free(numbers);
   *numbers = NULL;
}
In ogni caso mi sembra superfluo preoccuparsi di un leak quando il 99% dei programmi deve abortire in caso che il valore di ritorno sia NULL, quella memoria verrà comunque liberata. Chiaramente se il programma non deve abortire si DEVE ad ogni costo preoccuparsi di questa evenienza, ma non è detto che si debba liberare la memoria.
Non sempre: dipende dal s.o. e/o dal compilatore usato.

La deallocazione "automatica" delle risorse alla chiusura di un'applicazione è fortemente dipendente dalla piattaforma.
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
Old 29-02-2008, 09:57   #18
cionci
Senior Member
 
L'Avatar di cionci
 
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
Quote:
Originariamente inviato da cdimauro Guarda i messaggi
La deallocazione "automatica" delle risorse alla chiusura di un'applicazione è fortemente dipendente dalla piattaforma.
Ma parli di piattaforme embedded e sistemi realtime ?
cionci è offline   Rispondi citando il messaggio o parte di esso
Old 29-02-2008, 14:18   #19
cdimauro
Senior Member
 
L'Avatar di cdimauro
 
Iscritto dal: Jan 2002
Città: Germania
Messaggi: 26110
Non solo: http://www.aros.org/
__________________
Per iniziare a programmare c'è solo Python con questo o quest'altro (più avanzato) libro
@LinkedIn Non parlo in alcun modo a nome dell'azienda per la quale lavoro
Ho poco tempo per frequentare il forum; eventualmente, contattatemi in PVT o nel mio sito. Fanboys
cdimauro è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
La nave elettrica più grande mai ...
Spusu lancia il Wi-Fi Calling: come funz...
Questo robot impara a muovere le labbra ...
iPhone 17 annienta la concorrenza in Cin...
La nuova Xiaomi SU7 batte un record: 4.2...
È possibile copiare i qubit: dei ...
BYD alza ulteriormente l'asticella: batt...
Il nuovo razzo spaziale riutilizzabile c...
L'ex leader di Assassin's Creed porta Ub...
Il razzo spaziale NASA SLS e la capsula ...
Samsung Galaxy S26 Ultra: quattro colora...
AWS investe 1,2 miliardi in Italia. Coin...
La navicella cinese Shenzhou-20 con il f...
I piani Business ed Education di Google ...
Ceres-2 e Lunga Marcia 3B: la Cina falli...
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: 07:57.


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