Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto
be quiet! debutta nel settore mouse da gaming con Dark Perk Ergo e Dark Perk Sym: due modelli gemelli per specifiche, con polling rate di 8.000 Hz anche in wireless, sensore PixArt PAW3950 da 32.000 DPI e autonomia dichiarata fino a 110 ore. Nel test, a 8.000 Hz si arriva a circa 30 ore reali, con ricarica completa in un'ora e mezza
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker
Analizziamo nel dettaglio DJI RS 5, l'ultimo arrivato della famiglia Ronin progettato per videomaker solisti e piccoli studi. Tra tracciamento intelligente migliorato e ricarica ultra rapida, scopriamo come questo gimbal eleva la qualità delle produzioni.
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming
AMD Ryzen 7 9850X3D è la nuova CPU gaming di riferimento grazie alla 3D V-Cache di seconda generazione e frequenze fino a 5,6 GHz. Nei test offre prestazioni superiori a 9800X3D e 7800X3D, confermando la leadership AMD nel gaming su PC.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 04-10-2012, 10:24   #1
Dreamwolf_81
Member
 
L'Avatar di Dreamwolf_81
 
Iscritto dal: Apr 2003
Messaggi: 265
[C#] Passaggio per riferimento al costruttore

Ciao a tutti, ho una questione piuttosto ingarbugliata: devo passare un'istanza di una classe 'A' al costruttore di una classe 'B' e utilizzare il riferimento di 'A' (puntatore ???) all'interno di 'B'...faccio un esempio:

Codice:
public sealed class A
{
    ...
}

// La classe B contiene un thread in cui si deve fare riferimento ai dati di 'A'
// e non a una copia degli stessi.
public sealed class B
{
    // Questa istanza non dovrebbe essere una copia di 'A' ma un riferimento a essa
    A a_class;

    public B(ref A inst_of_a)
    {
        a_class = inst_of_a;
    }
}

void main()
{
    A inst_of_a = new A();
    // Faccio qualcosa con A...
    B inst_of_b = new B(ref inst_of_a);
}
Spero di essere stato chiaro e rimango in attesa di illuminazioni.

Grazie a tutti!
__________________
He said: Quando hai un nemico non ucciderlo, siediti sulla sponda del fiume e aspetta che passi il suo cadavere...

Ultima modifica di Dreamwolf_81 : 04-10-2012 alle 10:27.
Dreamwolf_81 è offline   Rispondi citando il messaggio o parte di esso
Old 04-10-2012, 10:39   #2
Dreamwolf_81
Member
 
L'Avatar di Dreamwolf_81
 
Iscritto dal: Apr 2003
Messaggi: 265
OK, scusate, risolto in altro modo!!!

Grazie lo stesso...potete chiudere la discussione!!
__________________
He said: Quando hai un nemico non ucciderlo, siediti sulla sponda del fiume e aspetta che passi il suo cadavere...
Dreamwolf_81 è offline   Rispondi citando il messaggio o parte di esso
Old 04-10-2012, 11:15   #3
[Kendall]
Senior Member
 
L'Avatar di [Kendall]
 
Iscritto dal: Jul 2005
Città: Vicenza
Messaggi: 1570
Quote:
Originariamente inviato da Dreamwolf_81 Guarda i messaggi
OK, scusate, risolto in altro modo!!!

Grazie lo stesso...potete chiudere la discussione!!
E' buona norma spiegare come hai risolto, almeno se qualcuno si trova nella stessa tua situazione vede come risolvere il tutto.

Comunque, non so se è quello che hai fatto, ma quando passi l'istanza di una classe (alias "un oggetto") ad un metodo cos'è che viene copiato?

Beh, viene copiato il contenuto dell'istanza (che può essere nullo o meno). Parlando con terminologia C (che forse è più facile per la spiegazione):
non viene copiato il "puntatore", ma il contenuto dello stesso, quindi per fare un esempio:

Codice:
public void MetodoProva(Pluto p)
{
   p = new Pluto();
   return;
}

public static void Main(string[] argv)
{
   Pluto obj = new Pluto();
   MetodoProva(obj);
}
In questo caso obj, dopo la chiamata di funzione, conterrà la stessa istanza iniziale, NON quella istanziata dentro a MetodoProva.
Passare l'istanza per riferimento aggira questa cosa, in quanto passi "il puntatore" e non il contenuto, e su esso puoi lavorare.

Piccola parentesi: la keyword "out" ha la stessa funzionalità di "ref", nel senso che specifica che la variabile viene passata per riferimento, ma ha due importanti conseguenze:

1) All'interno del metodo tu DEVI fare un assegnazione su di essa, fosse anche solo un assegnazione a NULL;
2) Puoi passare quella variabile al metodo anche se all'interno del codice chiamante essa non è stata assegnata (a differenza di "ref", che richiede invece una precedente assegnazione).


Detto questo, magari avevi già fatto queste considerazioni, ma non si sa mai...
[Kendall] è offline   Rispondi citando il messaggio o parte di esso
Old 04-10-2012, 13:12   #4
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Bisogna anche ricordare che in C# la copia di default avviene sempre per valore, anche i reference value vengono sempre passati per copia (del riferimento).
String essendo immutabile ha un comportamento "anomalo".
Viene sempre passato per riferimento, ma dato che nel metodo si ha a che fare con una copia del riferimento e dato che ogni modifica crea una nuova stringa, la reference fuori dal metodo continua a puntare alla vecchia istanza, mentre la reference all'interno del metodo punta alla nuova istanza.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 29-10-2012, 17:24   #5
digitalsound
Member
 
L'Avatar di digitalsound
 
Iscritto dal: Apr 2008
Città: Prov di TO
Messaggi: 136
Quote:
Originariamente inviato da [Kendall] Guarda i messaggi
E' buona norma spiegare come hai risolto, almeno se qualcuno si trova nella stessa tua situazione vede come risolvere il tutto.

Comunque, non so se è quello che hai fatto, ma quando passi l'istanza di una classe (alias "un oggetto") ad un metodo cos'è che viene copiato?

Beh, viene copiato il contenuto dell'istanza (che può essere nullo o meno). Parlando con terminologia C (che forse è più facile per la spiegazione):
non viene copiato il "puntatore", ma il contenuto dello stesso, quindi per fare un esempio:

Codice:
public void MetodoProva(Pluto p)
{
   p = new Pluto();
   return;
}

public static void Main(string[] argv)
{
   Pluto obj = new Pluto();
   MetodoProva(obj);
}
In questo caso obj, dopo la chiamata di funzione, conterrà la stessa istanza iniziale, NON quella istanziata dentro a MetodoProva.
Passare l'istanza per riferimento aggira questa cosa, in quanto passi "il puntatore" e non il contenuto, e su esso puoi lavorare.

Piccola parentesi: la keyword "out" ha la stessa funzionalità di "ref", nel senso che specifica che la variabile viene passata per riferimento, ma ha due importanti conseguenze:

1) All'interno del metodo tu DEVI fare un assegnazione su di essa, fosse anche solo un assegnazione a NULL;
2) Puoi passare quella variabile al metodo anche se all'interno del codice chiamante essa non è stata assegnata (a differenza di "ref", che richiede invece una precedente assegnazione).


Detto questo, magari avevi già fatto queste considerazioni, ma non si sa mai...
Le classi sono dei reference types ed in C# per default vengono sempre passate per riferimento, quindi NON viene copiata l'istanza, ma solo il reference, che risiede nello Stack.
Se copiasse l'istanza sarebbe un'operazione troppo dispendiosa per il CLR e le applicazioni .NET sarebbero molto più lente. Questa operazione in memoria si chiama Boxing/Unboxing a seconda se la copia avviene dallo stack all'heap o viceversa ed avviene per i value types(int, bool, double ecc).
Per passare una copia dell'istanza si utilizza il metodo Clone() se l'oggetto è un ICloneable, oppure si implementa la copia facendo una nuova istanza e valorizzandone le proprietà.
__________________
Motherboard: ASUS P8P67 EVO, CPU : INTEL Core i5 3570 Scheda Video: nVidia GTX 760, RAM: Kingston 2x4Gb SSD: Samsung 840 Evo, Scheda Audio: Creative Sound Blaster ZX, OS: Windows 8.1 Pro 64Bit
digitalsound è offline   Rispondi citando il messaggio o parte di esso
Old 29-10-2012, 19:34   #6
[Kendall]
Senior Member
 
L'Avatar di [Kendall]
 
Iscritto dal: Jul 2005
Città: Vicenza
Messaggi: 1570
Quote:
Originariamente inviato da digitalsound Guarda i messaggi
Le classi sono dei reference types ed in C# per default vengono sempre passate per riferimento, quindi NON viene copiata l'istanza, ma solo il reference, che risiede nello Stack.
Se copiasse l'istanza sarebbe un'operazione troppo dispendiosa per il CLR e le applicazioni .NET sarebbero molto più lente. Questa operazione in memoria si chiama Boxing/Unboxing a seconda se la copia avviene dallo stack all'heap o viceversa ed avviene per i value types(int, bool, double ecc).
Per passare una copia dell'istanza si utilizza il metodo Clone() se l'oggetto è un ICloneable, oppure si implementa la copia facendo una nuova istanza e valorizzandone le proprietà.
Forse mi sono spiegato male. Tanto che poi ho usato l'esempio del puntatore proprio per cercare di farmi capire meglio.

In C# le classi sono ovviamente dei reference type. Quello che intendevo dire io (però mi sa di essermi spiegato davvero male) è che quando passi un oggetto ad un metodo, il parametro formale che poi andremo ad usare dentro il metodo NON è la stessa variabile passata, ma ne contiene solo l'oggetto, o meglio il riferimento a quell'oggetto. Pertanto se io vado ad istanziare un nuovo oggetto all'interno del metodo e lo assegno al parametro formale, questa nuova istanza non sará vista dall'esterno, dal parametro attuale (vedi l'esempio che ho utilizzato nel mio post precedente).
Per poter lavorare sulla variabile originaria (quella passata al metodo) devo per forza di cose passarla con il parametro ref (quindi un riferimento del riferimento in pratica ).

In pratica non ho mai voluto parlare tanto dell'oggetto, quanto del riferimento.
[Kendall] è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
DJI RS 5: stabilizzazione e tracking intelligente per ogni videomaker DJI RS 5: stabilizzazione e tracking intelligent...
AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequenze al top per il gaming AMD Ryzen 7 9850X3D: Zen 5, 3D V-Cache e frequen...
Le soluzioni FSP per il 2026: potenza e IA al centro Le soluzioni FSP per il 2026: potenza e IA al ce...
AWS annuncia European Sovereign Cloud, il cloud sovrano per convincere l'Europa AWS annuncia European Sovereign Cloud, il cloud ...
Segway Navimow presenta la nuova gamma d...
Xiaomi SU7 Pro: l'ispezione dopo 265.000...
Nimbus Innovation Awards 2026: le miglio...
SSD Samsung contraffatto, ma Windows e C...
Enrique Lores, CEO e presidente di HP, l...
SoftBank e Intel preparano la 'memoria d...
Il blocco dei porno per i minori è...
AMD: i nuovi processori Zen 6 saranno (i...
Ancora aumenti per le schede video Radeo...
Sonos presenta Amp Multi a ISE 2026: il ...
Una funzione esclusiva dei Pixel potrebb...
La Cina vieta ufficialmente le maniglie ...
HP e lavoro ibrido: le nuove cuffie Poly...
MSI sta lavorando a un dissipatore ottim...
27 offerte Amazon, le prime 5 in elenco ...
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: 02:33.


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