Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta
Google ha appena rinnovato la sua celebre serie A con il Pixel 10a, lo smartphone della serie più conveniente se consideriamo il rapporto tra costo e prestazioni. Con il chip Tensor G4, un design raffinato soprattutto sul retro e l'integrazione profonda di Gemini, il colosso di Mountain View promette un'esperienza premium a un prezzo accessibile. E il retro non ha nessuno scalino
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026
Al MWC Qualcomm annuncia una coalizione industriale per lanciare il 6G entro il 2029 e introduce agenti IA per la gestione autonoma della RAN. Ericsson, presente sul palco, conferma la direzione: le reti del futuro saranno IA-native fin dalla progettazione
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso
CHUWI CoreBook Air è un ultraleggero da 1 kg con Ryzen 5 6600H, display 14" 16:10 e 16 GB LPDDR5. Offre buona portabilità, autonomia discreta e costruzione in alluminio, ma storage PCIe 3.0 e RAM saldata limitano l'espandibilità. A 549 euro sfida brand più noti nella stessa fascia di mercato.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 29-12-2012, 19:28   #1
cavallini25
Member
 
Iscritto dal: Oct 2007
Messaggi: 71
[C++] passaggio di parametri attraverso funzioni

Buonasera a tutti,

Vi sottopongo il listato prima di procedere alle domande:

Codice:
void foo1(int a, int b) { a=b; }
void foo2(int& a, int b) { a=b; }
void foo3(int* a, int* b) { a=b; }
void foo4(int* a, int* b) { *a=*b; }

void main() 
{
int m=3, n=5; 
foo1(m,n); 
cout << m << ’ ’ << n << ’\n’; 
m=3; 
n=5; 
foo2(m,n); 
cout << m << ’ ’ << n << ’\n’; 
m=3; 
n=5; 
foo3(&m,&n); 
cout << m << ’ ’ << n << ’\n’; 
m=3; 
n=5; 
foo4(&m,&n); 
cout << m << ’ ’ << n << ’\n’; 
}
l'output di questo programma è:
3 5
5 5
3 5
5 5

Quello che desideravo chiedervi era una delucidazione sul funzionamento del passaggio di parametri attraverso le funzioni.
E' palese che la funzione FOO1 crea una copia delle variabili al suo interno e ciò non modifica le variabili m ed n all'esterno della funzione.

Potete chiarirmi meglio il funzionamento e il ragionamento di come funziona il passaggio con i puntatori e le loro associazioni? (* e &)

Grazie in anticipo a tutti per i chiarimenti, spero di essere stato abbastanza chiaro nella domanda.

Saluti.
Marco.
cavallini25 è offline   Rispondi citando il messaggio o parte di esso
Old 29-12-2012, 23:40   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
Sia & che * possono avere due significati, a seconda del contesto.
* nella dichiarazione di una variabile, indica che la variabile sarà di tipo puntatore (a un certo tipo di dato, nel tuo esempio sempre int). Il fatto che una variabile sia di tipo puntatore significa che essa può contenere un indirizzo di memoria. Per leggere e scrivere il valore contenuto in questo indirizzo di memoria si "dereferenzia" la variabile anteponendo * (questo è il secondo significato di *). Quando invece usi una variabile di tipo puntatore senza * significa che stai agendo sull'indirizzo di memoria in essa contenuto.

&, anteposto a un valore contenuto in una variabile restituisce l'indirizzo di memoria in cui è contenuto quel valore.
Quando invece viene usato nella dichiarazione di un parametro x (notare che questa caratteristica è presente solo in C++ e non in C) significa che, quando la funzione verrà invocata, il valore di x verrà passato per riferimento, cioè, dietro le quinte, verrà passato l'indirizzo di x e nella funzione il parametro farà "riferimento" a quel valore (senza dover far uso dei puntatori e quindi senza dover deferenziare il parametro).
Mi rendo conto di non essere stato molto chiaro, provo a farti un esempio commentato:

Codice:
...
   int x = 1;
   foo(x); // l'indirizzo in cui sarà memorizzato byRef sarà lo stesso di x
   printf("%d", x); //Stampa 2
...
void foo(int& byRef){
   byRef++; //qui il tipo di byRef è int, non farti confondere dal & nella dichiarazione. L'& significa però che le modifiche fatte su byRef avvengono anche su x
}
Ho provato a spiegarti, spero di non averti confuso ulteriormente le idee...
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 09-01-2013, 16:40   #3
MaxN
Member
 
Iscritto dal: Oct 2005
Città: Cusano Milanino
Messaggi: 147
C passa i parametri per valore, sempre. Quando il compilatore incontra una chiamata a funzione non fa altro che prendere il valore degli argomenti, normalmente da destra a sinistra e caricarli sullo stack. Poi chiama la funzione.

Utilizzando la dichiarazione void f(int *p) dici solamente che p va considerato un puntatore, cioè un indirizzo di memoria, quindi di consentire le operazioni valide per quel tipo di dato.

Sta al tuo codice passare effettivamente un indirizzo quando chiami la funzione, per questo normalmente la chiamata a tale funzione sarebbe f(&a).

L'operatore unario & calcola l'indirizzo di memoria dove si trova la variabile specificata.

L'operatore unario *, utilizzato fuori dalla dichiarazione di una funzione, fa l'esatto opposto: recupera il valore memorizzato all'indirizzo di memoria specificato dalla variabile, ad esempio:

int *a;
int b;

a = 1234;
*a = 2; memorizza 2 all'indirizzo 1234

b = a; b vale 1234 anche se il compilatore segnala tale istruzione (warning in C errore in C++, la sintassi corretta sarebbe b = (int)a; )

b = *a; b vale 2

ipotizzando che b si trovi all'indirizzo 2345;

a = &b; a vale 2345, all'indirizzo 1234 è ancora memorizzato 2
MaxN è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Recensione Google Pixel 10a, si migliora poco ma è sempre un'ottima scelta Recensione Google Pixel 10a, si migliora poco ma...
6G, da rete che trasporta dati a rete intelligente: Qualcomm accelera al MWC 2026 6G, da rete che trasporta dati a rete intelligen...
CHUWI CoreBook Air alla prova: design premium, buona autonomia e qualche compromesso CHUWI CoreBook Air alla prova: design premium, b...
Roborock Saros 20: il robot preciso e molto sottile Roborock Saros 20: il robot preciso e molto sott...
ASUS ROG Kithara: quando HIFIMAN incontra il gaming con driver planari da 100mm ASUS ROG Kithara: quando HIFIMAN incontra il gam...
Portatile HP con 32GB di RAM, Core i5 e ...
AMD Ryzen AI 400 per desktop: interfacci...
Il Senato statunitense vorrebbe prolunga...
Leica aggiorna lo Store & Galerie Mi...
Artemis II: risolto il problema al razzo...
Hyundai e Kia investono in Qnovo: ottimi...
iPhone 17e sbarca su Amazon (con consegn...
Aptera prossima alla produzione in serie...
Amazon svela le protagoniste della serie...
Nuovi Apple MacBook Pro con M5 Pro e M5 ...
Wind Tre sceglie Ericsson per modernizza...
Il conflitto in Medio Oriente manda in f...
Le soluzioni di Google Cloud per portare...
OPPO e MediaTek: l'intelligenza artifici...
Dopo i cheater, Activision si scaglia co...
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:26.


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