Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Cineca inaugura Pitagora, il supercomputer Lenovo per la ricerca sulla fusione nucleare
Cineca inaugura Pitagora, il supercomputer Lenovo per la ricerca sulla fusione nucleare
Realizzato da Lenovo e installato presso il Cineca di Casalecchio di Reno, Pitagora offre circa 44 PFlop/s di potenza di calcolo ed è dedicato alla simulazione della fisica del plasma e allo studio dei materiali avanzati per la fusione, integrandosi nell’ecosistema del Tecnopolo di Bologna come infrastruttura strategica finanziata da EUROfusion e gestita in collaborazione con ENEA
Mova Z60 Ultra Roller Complete: pulisce bene grazie anche all'IA
Mova Z60 Ultra Roller Complete: pulisce bene grazie anche all'IA
Rullo di lavaggio dei pavimenti abbinato a un potente motore da 28.000 Pa e a bracci esterni che si estendono: queste, e molte altre, le caratteristiche tecniche di Z60 Ultra Roller Complete, l'ultimo robot di Mova che pulisce secondo le nostre preferenze oppure lasciando far tutto alla ricca logica di intelligenza artificiale integrata
Renault Twingo E-Tech Electric: che prezzo!
Renault Twingo E-Tech Electric: che prezzo!
Renault annuncia la nuova vettura compatta del segmento A, che strizza l'occhio alla tradizione del modello abbinandovi una motorizzazione completamente elettrica e caratteristiche ideali per i tragitti urbani. Renault Twingo E-Tech Electric punta su abitabilità, per una lunghezza di meno di 3,8 metri, abbinata a un prezzo di lancio senza incentivi di 20.000€
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 20-01-2009, 10:30   #1
D4rkAng3l
Bannato
 
Iscritto dal: Mar 2004
Città: Roma
Messaggi: 2682
[JAVA] Piccolo dubbio sugli array, helpme

Sul compito d'esame la professoressa mette quasi sempre un esercizio dove dato un pezzo di codice di una classe e di un main dobbiamo mostrare cosa succede in memoria (stack ed heap)...ora non mi serve sapere come si fà perchè bene o male me la cavicchio...ho solo un dubbio allucinante sugli array (lo sò è una cosa stupida e credo di sapere la risposta ma il dubbio permane in me)

Se ho il seguente codice:

Codice:
public class StranoOggetto {
       private int[] A;
    
       /** COSTRUTTORE:
           @param un array di interi
           @return un oggetto istanza della classe StranoOggetto */
       public StranoOggetto (int[] V) {
           int i;
           A = new int[V.length];		// Cosruisci A della stessa lunghezza del parametro ricevuto dal costruttore

           for (i=0; i<A.length; i++) A[i] = V[i]; 	// Copia in A gli elementi di V
       }

       public int[] getArray() {
			return A; 
		}
}
Codice:
public class Test {
	public static void main(String[] args) {
		int i;
		int[] x={4,5,6};
		StranoOggetto C = new StranoOggetto(x);
		b = “domani”;
		x[0] = 48; // 1
		x = C.getArray()
		x[0]++; // 2
	}
}
dove il primo codice è la classe StranoOggetto e l'altro codice è una classe di test che contiene il metodo main()

Il mio dubbio è riferito a cosa succede in memoria quando viene eseguito il costruttore della classe StranoOggetto

Quanto eseguo l'operazione:
for (i=0; i<A.length; i++) A[i] = V[i]; // Copia in A gli elementi di V

io stò copiando fisicamente tutti i valori interi presenti in V dentro ad A e non i riferimenti a tale valori, giusto? (perchè sono valori primitivi).

Mentre invece se avessi avuto che A e V erano vettor di oggetti, allora facendo A[i] = V[i] avrei copiato nelle celle di memoria di A i riferimenti agli oggetti che erano nelle celle di memoria di V.

Ho capito bene?

Grazie
Andrea
D4rkAng3l è offline   Rispondi citando il messaggio o parte di esso
Old 20-01-2009, 11:08   #2
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da D4rkAng3l Guarda i messaggi
...
Il mio dubbio è riferito a cosa succede in memoria quando viene eseguito il costruttore della classe StranoOggetto

Quanto eseguo l'operazione:
for (i=0; i<A.length; i++) A[i] = V[i]; // Copia in A gli elementi di V

io stò copiando fisicamente tutti i valori interi presenti in V dentro ad A e non i riferimenti a tale valori, giusto? (perchè sono valori primitivi).

Mentre invece se avessi avuto che A e V erano vettor di oggetti, allora facendo A[i] = V[i] avrei copiato nelle celle di memoria di A i riferimenti agli oggetti che erano nelle celle di memoria di V.

Ho capito bene?
Sì, quando fai l'assegnazione:
Codice:
for (i=0; i<A.length; i++) 
    A[i] = V[i];
con 'A' e 'V' che sono di tipo int[] stai copiando il valore di ogni singolo int contenuto nell'array V nell'array A.


Invece se A e V fossero stati array di oggetti, le cose sarebbero state diverse:
Codice:
// crea solo una reference ad array di Object; l'array viene inizializzato con lo stesso numero di elementi presenti in V
Object[] A = new Object[V.length];

// copia i valori degli elementi di V in A
for (i=0; i<A.length; i++) 
    A[i] = V[i];
con 'A' e 'V' che sono di tipo Object[] stai copiando il valore di ogni singolo elemento contenuto nell'array V nell'array A.
Essendo i due array di tipo Object[], copiare un elemento da uno all'altro significa copiare il valore di una reference a Object (l'elemento, appunto è una reference) nel valore dell'altra reference; il valore di una reference è l'indirizzo in memoria dell'oggetto puntato.

Quindi se poi si va a modificare qualcosa ad un elemento di V (esempio di fantasia):
Codice:
V[0].setValue(10);
si modifica l'oggetto puntato da quella reference e quindi la modifica è visibile anche dalle reference dell'array A, proprio perchè queste non fanno altro che puntare agli stessi Object di V.
Codice:
// ora
A[0].getValue();
// tornerebbe 10
In pratica A[0] e V[0] nel caso degli int accedono a due diverse 'entità' (due diverse variabili di tipo intero) mentre nel caso degli oggetti A[0] e V[0] accedono [a due diverse reference in memoria che però hanno lo stesso valore e quindi di fatto puntano] allo stesso oggetto.
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)

Ultima modifica di banryu79 : 20-01-2009 alle 11:13.
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 20-01-2009, 11:12   #3
D4rkAng3l
Bannato
 
Iscritto dal: Mar 2004
Città: Roma
Messaggi: 2682
Ok ti ringrazio, quindi la mia idea era corretta
Quindi se avessi avuto due array di Object per evitare possibili effetti collaterali (ovvero: se modifico un elemento di V mi si modifica anche un elemento di A) avrei dovuto farne una copia hard, giusto?

E tanto per approfondire bene...
un array è un intero, quindi starà nello heap e non nella stack, ogni oggetto punta a sua volta nello heap al record di allocazione della sua classe (che eventualmente contiene le variabili di classe ed il codice dei metodi di classe).

Quindi quando nel main si esegue l'istruzione: int[] x={4,5,6};

nella stack ho la variabile X che è un riferimento all'oggetto array nello heap che a suavolta punta al proprio record di allocazione della sua classe nello heap int[]

Giusto?
D4rkAng3l è offline   Rispondi citando il messaggio o parte di esso
Old 20-01-2009, 11:18   #4
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da D4rkAng3l Guarda i messaggi
Quindi quando nel main si esegue l'istruzione: int[] x={4,5,6};

nella stack ho la variabile X che è un riferimento all'oggetto array nello heap che a suavolta punta al proprio record di allocazione della sua classe nello heap int[]

Giusto?
Ecco, qui alzo le mani perchè in verità non conosco i dettagli di come sia gestito/piazzato in memoria un int[] in Java (avevo letto qualcosa su come vengono allocate le variabili e gli oggetti membro da parte della JVM quando deve inizializzare le classi ma è passato del tempo e non ricordo i dettagli).
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 20-01-2009, 11:27   #5
D4rkAng3l
Bannato
 
Iscritto dal: Mar 2004
Città: Roma
Messaggi: 2682
Quote:
Originariamente inviato da banryu79 Guarda i messaggi
Ecco, qui alzo le mani perchè in verità non conosco i dettagli di come sia gestito/piazzato in memoria un int[] in Java (avevo letto qualcosa su come vengono allocate le variabili e gli oggetti membro da parte della JVM quando deve inizializzare le classi ma è passato del tempo e non ricordo i dettagli).
Vabbè ti ringrazio, casomai glielo chiedo domani alla proff visto che è tanto fissata che gli disegnamo cosa succede nello stack e nello heap al compito
D4rkAng3l è offline   Rispondi citando il messaggio o parte di esso
Old 20-01-2009, 12:18   #6
fero86
Senior Member
 
Iscritto dal: Oct 2006
Città: Roma
Messaggi: 1383
Quote:
Originariamente inviato da D4rkAng3l Guarda i messaggi
Ho capito bene?
si, ma non é solo una questione di array: in generale in Java i tipi nativi vengono passati per copia di valore, mentre gli oggetti per copia di riferimento.
vale per tutto, anche per il passaggio di parametri o le comuni assegnazioni.
fero86 è offline   Rispondi citando il messaggio o parte di esso
Old 20-01-2009, 14:06   #7
banryu79
Senior Member
 
L'Avatar di banryu79
 
Iscritto dal: Oct 2007
Città: Padova
Messaggi: 4131
Quote:
Originariamente inviato da fero86 Guarda i messaggi
si, ma non é solo una questione di array: in generale in Java i tipi nativi vengono passati per copia di valore, mentre gli oggetti per copia di riferimento.
vale per tutto, anche per il passaggio di parametri o le comuni assegnazioni.
Sì, infatti nel linguaggio Java l'assegnamento/passaggio è sempre fatto per valore.

Questo potrebbe sembrare controintuitivo ma in realtà è così; in Java puoi avere solo due casi:
- tipi primitivi
Codice:
// primitiva di tipo int = valore letterale int
int a = 1;
- reference (riferimento a oggetto)
Codice:
// riferimento di tipo Object = oggetto
Object ref = new Object();
Cosa significa copiare il valore di una variabile di tipo primitivo in un'altra è abbastanza immediato.
Cosa significa copiare il valore di una reference in un'altra reference te l'ho spiegato sopra: equivale a copiare il valore di quella reference (un indirizzo) dentro a un'altra reference, in altri termini significa far puntare la seconda reference allo stesso oggetto a cui punta la prima.
__________________

As long as you are basically literate in programming, you should be able to express any logical relationship you understand.
If you don’t understand a logical relationship, you can use the attempt to program it as a means to learn about it.
(Chris Crawford)
banryu79 è offline   Rispondi citando il messaggio o parte di esso
Old 20-01-2009, 23:50   #8
malocchio
Senior Member
 
L'Avatar di malocchio
 
Iscritto dal: Feb 2007
Città: Verona
Messaggi: 1060
Gli array (tutti i tipi) stanno nell'heap. Nello stack ci stanno solo le variabili primitive o reference (ad oggetto o array) dichiarate all'interno di un metodo, o in un blocco di codice tipo if o ciclo di qualsiasi tipo.

variabili d'istanza -> heap
variabili locali (chiamate anche variabili automatiche perché si "autodistruggono" alla fine del blocco di codice) -> stack

Il modo migliore per capire dove sta una variabile è guardare dov'è stata dichiarata.
__________________
malocchio è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Cineca inaugura Pitagora, il supercomputer Lenovo per la ricerca sulla fusione nucleare Cineca inaugura Pitagora, il supercomputer Lenov...
Mova Z60 Ultra Roller Complete: pulisce bene grazie anche all'IA Mova Z60 Ultra Roller Complete: pulisce bene gra...
Renault Twingo E-Tech Electric: che prezzo! Renault Twingo E-Tech Electric: che prezzo!
Il cuore digitale di F1 a Biggin Hill: l'infrastruttura Lenovo dietro la produzione media Il cuore digitale di F1 a Biggin Hill: l'infrast...
DJI Osmo Mobile 8: lo stabilizzatore per smartphone con tracking multiplo e asta telescopica DJI Osmo Mobile 8: lo stabilizzatore per smartph...
HONOR 500 Pro, scheda tecnica confermata...
GeForce NOW si prepara a vivere un mese ...
Exynos 2600: temperature più bass...
Apple si ispirerà a Nothing? Back...
Da Intel ad AMD, il grande salto di Kulk...
Velocità 12 volte superiore a que...
Una piccola Morte Nera è gi&agrav...
Sei frodi che minacciano gli utenti nel ...
BioShock 4: Take-Two rassicura sullo svi...
Tesla, Musk promette FSD 'quasi pronto' ...
BioWare conferma: il nuovo Mass Effect &...
5 robot aspirapolvere di fascia alta in ...
Xiaomi Redmi Note 14 5G a 179€ è ...
Veri affari con gli sconti de 15% Amazon...
Tutti gli iPhone 16 128GB a 699€, 16e a ...
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: 21:36.


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