Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless
MSI FORGE GK600 TKL WIRELESS: switch lineari hot-swap, tripla connettività, display LCD e 5 strati di fonoassorbimento. Ottima in gaming, a 79,99 euro
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici
DJI porta un importante aggiornamento alla sua linea di gimbal camera tascabili con Osmo Pocket 4: sensore CMOS da 1 pollice rinnovato, gamma dinamica a 14 stop, profilo colore D-Log a 10 bit, slow motion a 4K/240fps e 107 GB di archiviazione integrata. Un prodotto pensato per i creator avanzati, ma che convince anche per l'uso quotidiano
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori
Il primo headset open-back della linea INZONE arriva a 200 euro con driver derivati dalle cuffie da studio MDR-MV1 e un peso record di soli 199 grammi
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 12-11-2010, 17:20   #1
ozisam
Junior Member
 
Iscritto dal: Sep 2008
Messaggi: 11
Allocazione dinamica in [C]

Ciao a tutti e spero che mi possiate aiutare!

Ho un problema con l'allocazione dinamica di strutture dati come liste concatenate etc.
Ho scritto un esempio per far capire cosa mi interessa fare.
La funzione scrivi alloca un vettore di n interi e ci inserisce numeri da 0 a 9.
La funzione stampa dovrebbe visualizzare gli elementi del vettore.
Così com'è non funziona.
Funziona invece se sposto la funzione 'calloc' nel main.
La mia domanda è: c'è un modo per allocare la memoria nella funzione e non nel main?

#include <stdio.h>
#include <stdlib.h>
#include <malloc.h>

void scrivi(int *, int n);
void stampa(int *, int n);

int main(void){
int *p;
scrivi(p,10);
stampa(p,10);
fflush(stdin);
getchar();
}

// Alloca un vettore di n interi e lo popola
void scrivi(int *punt, int n){
punt=(int *)calloc(10, sizeof(int));
int i;
for(i=0; i<n; i++){
punt[i]=i;
}
}

// Stampa un vettore di n interi
void stampa(int *punt, int n){
int i;
for(i=0; i<n; i++)
printf("%d", punt[i]);

}

Ultima modifica di ozisam : 12-11-2010 alle 18:23.
ozisam è offline   Rispondi citando il messaggio o parte di esso
Old 12-11-2010, 18:52   #2
tuccio`
Senior Member
 
Iscritto dal: Apr 2010
Città: Frosinone
Messaggi: 416
il motivo per cui non funziona è che fai un passaggio per valore del puntatore, p nel main non viene modificato e probabilmente non punta a niente di utile.

puoi passare p per riferimento o ritornare il valore ritornato da calloc, per assegnare tale valore a p nel main

comunque trovo più sensato che una funzione che si chiama "scrivi" non allochi, ma scriva

inoltre dovresti controllare che calloc non abbia ritornato NULL per verificare se c'è stato un errore
tuccio` è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2010, 09:41   #3
ozisam
Junior Member
 
Iscritto dal: Sep 2008
Messaggi: 11
Scusa ma non ho mica capito cosa intendi per passaggio del puntatore per riferimento.
Devo passare un puntatore a puntatore?

del tipo:
scrivi(&p, 10);

e modificare il prototipo della funzione in:
void scrivi(int **punt, int n);
ozisam è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2010, 10:06   #4
Dânêl
Senior Member
 
Iscritto dal: Jul 2008
Messaggi: 485
Esattamente
Se non usi un puntatore ad un puntatore (alias passaggio per riferimento del puntatore) la funzione scrivi lavorerà su una copia del punatore che viene distrutto al termine della funzione e il puntatore dichiarato nel main non viene toccato in alcun modo. Dovendolo modificare, devi passarne l'indirizzo alla funzione.

Come suggerito inoltre da tuccio` sarebbe meglio posizionare la chiamata a calloc (e la verifica del parametro di ritorno che non hai scritto) nel main, altrimenti dovresti denominare la funzione in un altro modo. Questa come norma generale di buona stesura di codice
Dânêl è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2010, 10:06   #5
goldorak
Senior Member
 
Iscritto dal: Apr 2003
Messaggi: 16462
Quote:
Originariamente inviato da ozisam Guarda i messaggi
Scusa ma non ho mica capito cosa intendi per passaggio del puntatore per riferimento.
Devo passare un puntatore a puntatore?

del tipo:
scrivi(&p, 10);

e modificare il prototipo della funzione in:
void scrivi(int **punt, int n);
Si si puo' fare cosi' ma perche' complicarsi la vita ?

Basta che cambi il prototipo della funzione scrivi in questo senso

Codice:
int * scrivi (int n) ;
La funzione scrivi alloca un array di n elementi e ti restituisce l'indirizzo base. Nel main poi assegni questo valore a p.
__________________
MICROSOFT : Violating your privacy is our priority
goldorak è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2010, 10:20   #6
WarDuck
Senior Member
 
L'Avatar di WarDuck
 
Iscritto dal: May 2001
Messaggi: 12966
Concordo con goldorak, è meglio evitare, ove possibile, di scrivere funzioni che compiono side-effect di quel tipo sui parametri.
WarDuck è offline   Rispondi citando il messaggio o parte di esso
Old 13-11-2010, 10:49   #7
ozisam
Junior Member
 
Iscritto dal: Sep 2008
Messaggi: 11
Ok grazie mille a tutti per le risposte chiare e precise.

Il codice che ho postato era giusto un esempio di cosa mi interessava fare, in realtà volevo applicare questo metodo su strutture più complesse.
Avevo già risolto ritornando il puntatore alla struttura come suggerito da goldorak ma ero curioso di sapere se si potesse fare in altro modo, e ho capito che non mi conviene.

Grazie di nuovo e ciao!!!!
ozisam è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Tastiera gaming MSI GK600 TKL: switch hot-swap, display LCD e tre modalità wireless Tastiera gaming MSI GK600 TKL: switch hot-swap, ...
DJI Osmo Pocket 4: la gimbal camera tascabile cresce e ha nuovi controlli fisici DJI Osmo Pocket 4: la gimbal camera tascabile cr...
Sony INZONE H6 Air: il primo headset open-back di Sony per giocatori Sony INZONE H6 Air: il primo headset open-back d...
Nutanix cambia pelle: dall’iperconvergenza alla piattaforma full stack per cloud ibrido e IA Nutanix cambia pelle: dall’iperconvergenza alla ...
Recensione Xiaomi Pad 8 Pro: potenza bruta e HyperOS 3 per sfidare la fascia alta Recensione Xiaomi Pad 8 Pro: potenza bruta e Hyp...
Il cofondatore di Netflix ha lasciato l'...
ASUS porta in Italia il nuovo Zenbook Du...
Assassin's Creed: Black Flag Resynced, s...
Xbox Game Pass cambierà: tra le n...
I nuovi Surface Pro e Laptop sono vicini...
OnePlus ci riprova con la fascia bassa: ...
La Top 10 delle offerte Amazon del weeke...
XGIMI MoGo 2 Pro a 339€: Google TV con N...
Forum IT & Intelligence 2026: dall'A...
iPhone 16e per la prima volta a meno di ...
Stop Killing Games: Ross Scott convince ...
Annunciata la tuta di volo di Vast che s...
Vast presenta il nuovo Large Docking Ada...
Una denuncia getta ombre sulle batterie ...
DJI Avata 2 Fly Smart Combo a 526€: il d...
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: 14:07.


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