Ciao a tutti
ho trovato un modo per dichiarare più classi pubbliche nello stesso file
java
es:
public class MyMainClass{
public aSmalSupportClass{
}
}
esistono contro indicazioni a questo tipo di approccio, il mio
obbiettivo e' di non fare troppi file piccoli per le classi di supporto
che contengono poca logica e quasi esclusivamente proprietà
saluti
Cris.
Ciao,
questo va sotto il nome di "inner classes". Prova a googlare il
termine, per vedere use cases.
Non so perche` ti danno fastidio file piccoli..., ma non dovrebbe
essere quello il criterio che ti detta la struttura del tuo codice ;)
Bye,
Chris.
--
You received this message because you are subscribed to the Google Groups "JUG Trentino Alto Adige Suedtirol" group.
To post to this group, send email to jug...@googlegroups.com.
To unsubscribe from this group, send email to jugtaa+unsubscribe@googlegroups.com.
Visit this group at http://groups.google.com/group/jugtaa?hl=en.
For more options, visit https://groups.google.com/groups/opt_out.
http://docs.oracle.com/javase/tutorial/java/javaOO/nested.html
Per il tuo scopo forse sarebbe meglio usare una static nested class. Sei voi usare una inner class non dimenticati che queste hanno una reference con l`outer class (e ti può capitare una memory leak (http://frickelblog.wordpress.com/2011/06/02/how-to-create-memory-leaks-by-using-inner-classes/)
To unsubscribe from this group and stop receiving emails from it, send an email to jugtaa+un...@googlegroups.com.
To post to this group, send email to jug...@googlegroups.com.
To unsubscribe from this group, send email to jugtaa+un...@googlegroups.com.
Il giorno 25/gen/2013 22:46, "Cristiano Tomasi" <ctom...@gmail.com> ha scritto:
>
> Ciao Chris
>
> grazie del suggerimento, il problema non sono i file piccoli, ma i tanti file, ti faccio l'esempio pratico che sto affrontando
>
> se devo fare una classe UndoManager, che ha bisogno di una classe UndoBlock che ha bisogno di una classe UndoAction, avendole separate in più file in caso di debug, di errore nel codice e cosi via devo sempre saltare da una paletta all'altra nell'IDE mentre se sono tutte nello stesso file le trovo molto più velocemente.
Questo non mi sembra un criterio molto valido, la struttura di un progetto dovrebbe credo osservare criteri di logica interna e chiarezza, non quella di "risparmio di click" per chi programma.
> Oltre tutto queste tre classi sono le sole classi che mi servono per implementare le mie operazioni di undo e quindi e anche logico raggrupparle in un unico "blocco"
Questo mi sembra invece molto ragionevole; solitamente le inner classe sono classi private, usate solamente all'interno della classe che le racchiude, a cui offrono metodi di supporto.
In alcune occasioni si vede addirittura una classe definita contestualmente alla "new" con cui la si istanzia. Poco leggibile in generale, ma ha il vantaggio di raggruppare tutto il codice nell'unico punto in cui viene utilizzato. Un esempio è questo timer, che prevede come parametro un listener dichiarato al volo (riga 570):
ciao,
rob