|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 | ||||
|
Senior Member
Iscritto dal: Feb 2002
Messaggi: 1370
|
[JAVA] dubbio sui tipi di dato
Ciao a tutti, programmo già da qualche anno in java, attualmente sto cercando di approfondirlo ed ho un dubbio sui tipi di dato primitivi che spero qualcuno di voi possa aiutarmi a chiarire.
Se io scrivo Quote:
e se scrivo Quote:
a2 a cosa punta ad un oggetto che contiene "pippo"? Se scrivo Quote:
Ma se creo una terza stringa Quote:
Qualcuno può chiarirmi questo comportamento? In particolare scrivendo a2= new String("pippo"); a cosa punta a2? |
||||
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Dec 2006
Messaggi: 3808
|
ti mancano 2 concetti per capire il tutto:
- il concetto di "string literal pool" - cosa faccia l'operatore new in Java, come in molti altri linguaggi, scrivi il tuo sorgente, quando finisci lo mandi in compilazione per crearti, nel caso specifico di Java, del bytecode, molto semplice. Ora c'è una cosa che Java, o meglio javac, fa in automatico, cioé effettua il parsing del tuo codice e se trova delle stringhe, cioé delle parole, delle frasi, le include in un "pool" appunto lo "string literal pool", se la stringa si ripete 2, 3, 10 volte nel tuo codice, comparirà sempre 1 volta nel pool ma verrà soltanto referenziata 2-3-10 volte; cioé Java sfrutta tantissimo meccanismi di referenziazione, passaggi di idirizzi interni alla JVM se vogliamo metterla così, piuttosto che occupare memoria per 10 stringhe tutte uguali, ne conserva 1 copia nel pool e quelle 10 stringhe sono in realtà un riferimento a quella presente nel pool. Questo è quanto avviene secondo automatismi propri di Java riguardo le costanti stringa. Quando usi new tu imponi a Java di fare principalmente 2 cose: - usare il costruttore per il tipo specificato alla destra dell'operatore new - creare forzatamente 1 nuovo oggetto del tipo di cui sopra e mantenerne il riferimento quando tu scrivi 20 volte nel tuo codice Codice:
"Ciao forum" Codice:
new String("Ciao forum")
|
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Jan 2007
Messaggi: 2267
|
Le stringhe create con la notazione "..." hanno un nome...che non ricordo e seguono una logica diversa di allocazione in memoria rispetto alle stringhe create con il costruttore della classe String.
Con == stai testando l'uguaglianza del reference...non del contenuto. Per testare l'uguaglianza del contenuto di oggetti devi usare equals. E' corretto che a ed a3 siano ugual nel senso di ==...poichè il litterale "pippo" risiede in un'area di memoria a cui entrambe puntano. new String("pippo") invece risiede in un'area di memoria diversa. Se dopo riesco cerco dove lo avevo letto che era (ovviamente) spiegato meglio. Comunque prova a fare qualche ricerca sulla differenza tra stringhe create con "" e con new String().
__________________
Concluso con:... Ultima modifica di Floris : 23-10-2011 alle 18:33. |
|
|
|
|
|
#4 | |||
|
Senior Member
Iscritto dal: Feb 2002
Messaggi: 1370
|
Ok, grazie ad entrambi, ho capito qual'è la gestione delle stringhe.
Già che ci sono vi faccio un paio di domande sugli interi.. Se scrivo Quote:
e se scrivo Quote:
In questo caso sicuramente b punterà ad un oggetto contenente il valore 1. Perchè allora si verifica questo? Quote:
a = b b e c sono diversi c = a Perché a==b mi restituisce true? Se int a contiene direttamente il valore 1 allora dovrebbe essere diverso da b che invece contiene un puntatore all'oggetto contenente 1. Se al contrario int contiene un puntatore all'oggetto contenente 1 suppongo sia comunque un oggetto diverso dall'oggetto a cui punta b visto che per b ho utilizzato la parola chiave new e quindi i due oggetti contenenti il valore 1 dovrebbero comunque essere diversi. |
|||
|
|
|
|
|
#5 | |
|
Senior Member
Iscritto dal: Dec 2006
Messaggi: 3808
|
Quote:
Codice:
int a Codice:
Integer ciò che avviene in questo caso è spiegato dai meccanismi di boxing e unboxing, ricorda comunque l'uso dell'operatore di confronto == unitamente alle sole etichette delle varie variabili e dei vari oggetti può dar luogo a situazioni logicamente errate e non è la strada migliore, inoltre con la sola etichetta, nella semantica dei riferimenti, si indica il riferimento ( l'indirizzo ) all'oggetto e non il suo valore. guardati boxing, unboxing, tipi primitivi, semantica dei valori e semantica dei riferimenti/indirizzi. |
|
|
|
|
|
|
#6 | |
|
Senior Member
Iscritto dal: Jan 2007
Messaggi: 2267
|
Come dice Freaxxx quando si mischiano e confrontano tipi primitivi ed oggetti le cose possono diventare strane. Sarebbe preferibile usare sempre e solo oggetti ovvero Integer. Purtroppo Java non é un linguaggio ad oggetti puro poichè contiene ad esempio tipi che non sono oggetti. Inoltre i refrence possono creare problemi di interferenza. Come diceva un mio professore:
Quote:
A parte tutto, sul momento non saprei dirti il perchè di quell'output. Bisognerebbe guardare alla specifica sematica di == quando un membro è un tipo primitivo e l'altro è un oggetto. Probabilmente, come suggerisce Freaxxx, il compilatore aggiunge una conversione implicita richiamando il metodo intValue di Integer. Ovvero a == b diventa qualcosa del tipo a == b.intValue(). Ricordati comunque che conviene usare sempre il metodo equals per effettuare confronti.
__________________
Concluso con:... |
|
|
|
|
|
|
#7 |
|
Senior Member
Iscritto dal: Mar 2007
Città: Milano Beach
Messaggi: 1696
|
Edit... mi ero perso un po' di reply.
__________________
~ Cthulhu: MacBookPro 13.3" ~ Azathoth: D510MO Ultima modifica di GByTe87 : 23-10-2011 alle 19:57. |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 12:45.




















