|
|
|
![]() |
|
Strumenti |
![]() |
#1 |
Member
Iscritto dal: May 2006
Messaggi: 86
|
[Java] Array di Oggetti
Ciao a tutti ... sto cercando di muovere i primi passi con java dopo diverso tempo dedicato al javascript e al c.
Non avendo mai toccato l'idea di classe, o qualche problema a livello "concettuale", ma qua credo che il problema sia un altro, e penso sia dovuto alla dichiarazione dell'Array, ma qualcosa mi sfugge. Idee? Codice:
package Test; import java.util.*; public class Contatti { Contatto Elenco[] = new Contatto[10]; Elenco[0] = new Contatto(); } class Contatto { Contatto(){ System.out.println("Costruttore Richiamato"); } private String name = new String(); public void setName(String s){ name = s; System.out.println("Name Set"); } } Ultima modifica di BlackAuron : 02-01-2010 alle 21:47. |
![]() |
![]() |
![]() |
#2 |
Senior Member
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
|
Codice:
public class Contatti { Contatto Elenco[] = new Contatto[10]; public Contatti() { Elenco[0] = new Contatto(); } }
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me! |
![]() |
![]() |
![]() |
#3 |
Junior Member
Iscritto dal: Mar 2009
Messaggi: 27
|
|
![]() |
![]() |
![]() |
#5 |
Senior Member
Iscritto dal: Mar 2007
Messaggi: 7863
|
infatti, perchè?
|
![]() |
![]() |
![]() |
#6 |
Junior Member
Iscritto dal: Mar 2009
Messaggi: 27
|
Ma perchè secondo voi il costruttore a che serve?
Per definizione, il costruttore è un metodo che serve per inizializzare gli attributi di una classe, ecc. L'inizializzazione degli attributi nella loro dichiarazione è una cosa stile paradigma imperativo, invece, in quello ad oggetti è buona norma inizializzarlo nel costruttore. Poi ognuno lo fa come gli piace, nessuno si lamenta, nemmeno il compilatore! |
![]() |
![]() |
![]() |
#7 |
Senior Member
Iscritto dal: Mar 2007
Messaggi: 7863
|
Il costruttore serve ad inizializzare a valori specifici i campi, ma se questi sono comuni per tutti i tipi di istanze creabili, è bene inizializzarli in fase di dichiarazione. Per di più, java, utilizza le inizializzazione di default ed inserisce il costruttore vuoto, in assenza di altre dichiarazioni.
|
![]() |
![]() |
![]() |
#8 |
Senior Member
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
|
Le "buone norme" possono essere suggestive ma sono pericolose perchè generalmente non hanno un riscontro obiettivo.
Uno usa o non usa una caratteristica del linguaggio secondo l'aderenza dei suoi presupposti e dei suoi effetti al risultato che vuole ottenere. Per Java, riguardo all'inizializzazione dei campi, vale quanto segue: 1. se il valore iniziale del campo deve essere quello predefinito -> dichiarazione senza inizializzazione. 2. se il valore iniziale del campo è diverso da quello predefinito e dipende da espressioni computabili a partire dal valore iniziale di campi precedenti o di costanti -> dichiarazione con inizializzazione. 3. se l'espressione di inizializzazione di cui al punto 2 richiede la dichiarazione di variabili computabili a partire da costanti o da valori di altri campi e quelle variabili non sono a loro volta campi -> inizializzazione in un blocco di inizializzazione. 4. se il valore iniziale del campo dipende da valori esterni alla classe dell'istanza inizializzata -> inizializzazione nel costruttore. La 4 vale anche nel caso in cui la procedura di inizializzazione possa essere decidibile da un sottotipo tramite l'invocazione di supercostruttore alternativo. E', se vogliamo, un esercizio di sintesi: ripeto, uno scrive quanto è strettamente necessario all'effetto che vuole ottenere.
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me! |
![]() |
![]() |
![]() |
#9 |
Junior Member
Iscritto dal: Mar 2009
Messaggi: 27
|
Alt, voi parlate strettamente di Java...dovreste pensare nell'ottica generale di programmazione ad oggetti.
E' normale che se parlate di java dite "vabbè questo lo posso evitare tanto ci pensa lui, bla, bla, ecc" ma se parlate in un contesto generale, teoria vera e propria di programmazione ad oggetti la cosa cambia. Se parlate di C++, beh...li l'inizializzazione di quel tipo nn ci sta un po' malino? del resto sfogliando il libro trovate "in C++ è possibile inizializzare una variabile nella sua dichiarazione", e qui di nuovo alt, si parla di variabile, non di attributi. Per quanto possano essere simili, variabili ed attributi sono cose totalmente diverse. Poi vabbè, in qualsiasi libro di Java, compresi i miei, trovate le assegnazioni di default, ecc...ma se prendete un libro di teoria di programmazione ad oggetti? beh, le cose cambiano...perciò stiamo attenti a distinguere cosa fa Java e cosa è realmente la programmazione ad oggetti. |
![]() |
![]() |
![]() |
#10 |
Senior Member
Iscritto dal: Nov 2004
Città: Tra Verona e Mantova
Messaggi: 4553
|
In un topic su Java si suppone che si dia una risposta su Java. Da un punto di vista orientato agli oggetti la questione è irrilevante.
__________________
Uilliam Scecspir ti fa un baffo? Gioffri Cioser era uno straccione? E allora blogga anche tu, in inglese come me! |
![]() |
![]() |
![]() |
#11 |
Junior Member
Iscritto dal: Mar 2009
Messaggi: 27
|
Certo, si dice così per ogni linguaggio.
|
![]() |
![]() |
![]() |
#12 |
Senior Member
Iscritto dal: Mar 2005
Città: Morimondo city
Messaggi: 5491
|
mah a dire il vero la tendenza ormai è di usare getter e setter,e poi tu dici di fare riferimento alla teoria generale e poi fai esempi con il C++
__________________
Khelidan |
![]() |
![]() |
![]() |
#13 |
Junior Member
Iscritto dal: Mar 2009
Messaggi: 27
|
Con getter e setter tu ti riferisci al name masking che è tutta un'altra cosa, con scopi diversi, che già esisteva prima ancora della programmazione ad oggetti...solo che adesso va di moda.
|
![]() |
![]() |
![]() |
Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 22:04.