|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Senior Member
Iscritto dal: Nov 2000
Messaggi: 279
|
Negare l'istanziazione!!
Negare l'istanziazione!! Preferibilmente in C#
Mi potete fare un esempio in qualsisasi linguaggio di come potrebbe essere possibile, se mai è possibile, negare l'instanziazione da costruttore?? ES(un po' cialtrone perchè lo faccio sul momento): public class Servizi public Servizi(string username,string password) { if ((username=="CIAO") && (password=="CIAO")) { // OK TUTTO A POSTO } else { // ANNULLA L'ISTANZA } } } Ora.. potrei che ne so mettere una variabile "isaccessible" = false che viene controllata da TUTTI i metodi e propietà prima che si eseguino ma..NON MI SEMBRA ELEGANTE non mi sembra nè
__________________
In un arco di tempo abbastanza lungo l'indice di sopravvivenza di ognuno scende a zero |
|
|
|
|
|
#2 | |
|
Bannato
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
|
Re: Negare l'istanziazione!!
Quote:
Codice:
public class Servizi
public Servizi(string username,string password) {
if ((username=="CIAO") && (password=="CIAO")) {
// OK TUTTO A POSTO
}
else {
throw Error("blablalba");
}
}
Codice:
...
try {
x = new Servizi("pinco","pallino");
} catch( Error e )
{
...
}
Una alternativa e' fare una classe apposita che costruisca (o meno) l'oggetto di cui hai bisogno: Codice:
public class ServiceFactory
{
public Servizi getService( string username, string password )
{
...
}
}
|
|
|
|
|
|
|
#3 |
|
Senior Member
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
|
Re: Negare l'istanziazione!!
non conosco C#, ma in Java puoi farlo creando SOLO un costruttore senza argomenti e dichiarandolo private.
|
|
|
|
|
|
#4 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Vuoi che ci sia una sola istanza di quella classe in memoria ?
|
|
|
|
|
|
#5 |
|
Senior Member
Iscritto dal: Jul 1999
Città: Torino
Messaggi: 2221
|
In java esiste la classe IllegalArgumentException()...come ti hanno suggerito puoi lanciare un eccezione, ma non generica!
throw new IllegalArgumentException("tuo messaggio"); is very elegant |
|
|
|
|
|
#6 | |
|
Senior Member
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
|
Quote:
son punti di vista ma per me lanciare sempre un'eccezione in un costruttore per non fare istanziare un oggetto e' dal punto di vista del design e' orrido, non elegante. Un'eccezione (come dice il nome) serve a notificare al chiamante che si e' verificato un problema (infrastruturale, NON applicativo) su una chiamata. E' l'intefaccia che fornisci che deve condizionare la chiamata, non un'eccezione! Se vuoi condizionare l'istanziazione di un oggetto esiste un patter chiamato factory (con decine di varianti) che fa al caso tuo. tutto IMHO, naturalmente |
|
|
|
|
|
|
#7 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Se io la facessi in C++ farei così...ma funziona grazie ai puntatori...
Codice:
class Servizi {
Servizi() { /*costruttore di default*/ }; //privato, non richiamabile direttamente
public:
static Servizi* Autentifica(string user, string pass); //deve essere static
};
Servizi* Servizi::Autentifica(string user, string pass)
{
if(user == "ciao" && pass == "ciao")
return new Servizi;
else
return NULL;
}
//Si usa in questo modo:
Servizi *s = Servizi::Autentifica("pippo", "pluto");
if(s)
//allocato
else
//non allocato
http://www.devhood.com/tutorials/tutorial_details.aspx?tutorial_id=486 |
|
|
|
|
|
#8 |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Aggiungo che anche secondo me usare un'eccezione è come ammazzare una mosca con una cannonata...senza contare che è stilisticamente brutto...ma brutto brutto brutto...
|
|
|
|
|
|
#9 | |
|
Senior Member
Iscritto dal: Nov 2000
Messaggi: 279
|
Re: Negare l'istanziazione!!
Innanzi tutto Grazie a tutti....
L'idea di lanciare l'eccezione è funzionale ma certo.. come dice Cionci... brutta brutta brutta.... Ecco invece è una buona idea l'ultima di /\/\@®¢Ø.... penso che farò così!! Quote:
__________________
In un arco di tempo abbastanza lungo l'indice di sopravvivenza di ognuno scende a zero |
|
|
|
|
|
|
#10 |
|
Senior Member
Iscritto dal: Oct 2001
Città: Scorzè (VE)
Messaggi: 853
|
puoi anche, come diceva kingv, usare un metodo statico per avere l'istanza della classe che ti interessa e dichiarare il costruttore privato:
Codice:
public class Servizi{
private Servizi(){
super(); //costruttore ereditato da Object
}
public static Servizi getServizi(string username,string password) {
if ((username=="CIAO") && (password=="CIAO")) {
return new Servizi();
}
else {
return null; //oppure throw new IllegalArgumentException("blah blah blah");
}
}
}
__________________
Mr. T. |
|
|
|
|
|
#11 | |
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Quote:
|
|
|
|
|
|
|
#12 |
|
Senior Member
Iscritto dal: Oct 2001
Città: Scorzè (VE)
Messaggi: 853
|
esatto
Ciao defender
__________________
Mr. T. |
|
|
|
|
|
#13 |
|
Senior Member
Iscritto dal: Nov 2000
Messaggi: 279
|
!!
..anche :-))
Forse è anzi più chiaro e razionale con il metodo statico... Grazie ancora :-D
__________________
In un arco di tempo abbastanza lungo l'indice di sopravvivenza di ognuno scende a zero |
|
|
|
|
|
#14 | |||
|
Bannato
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
|
Quote:
Oltretutto l'eccezione (come dice il nome Quote:
Quote:
Comunque non e' necessariamente detto che le factory siano la cosa migliore, perlomeno se il solo scopo e' controllare i parametri. In fondo un wrapper attorno al costruttore non e' poi molto differente da un try-catch , e scrivi pure piu' codice. |
|||
|
|
|
|
|
#15 | |||
|
Senior Member
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
|
Quote:
mettiamo che tu abbia un'applicazione che controlla il saldo di conto corrente perche' deve fare un bonifico. Se la comunicazione appc (o qualsiasi altra cosa usi per collegarti ad host) crasha ( Quote:
come sopra, perche' lanciare un'eccezione quando puoi scrivere "return false"? Quote:
|
|||
|
|
|
|
|
#16 |
|
Senior Member
Iscritto dal: Jul 1999
Città: Torino
Messaggi: 2221
|
Lanciare un'eccezione non è affatto brutto, brutto, brutto, brutto... ne tantomeno poco "stilistico". Esiste fior di letterautura su come creare classi di eccezione ad arte per adattarsi agli scopi funzionali.
Allora tanto vale per risolvere il problema del nostro amico controllare a priori, prima di istanziare l'oggetto, che i parametri siano accettabili. Naturalmente IMHO |
|
|
|
|
|
#17 | |||
|
Bannato
Iscritto dal: Jul 2000
Città: Malo (VI)
Messaggi: 1000
|
Quote:
Come dicevo sompra l'eccezione e' comoda e giustificata se posso lanciarla in molte parti e raccoglierla in una ( o poche ) cosi' che il codice "in mezzo" puo' fregarsene, a vantaggio della leggibilita'. Un esempio e' quello che fai tu, ma non e' comunque un concetto piu' generale Quote:
if ( x != null ){ ... } else { ... } l'eccezione puo' essere una buona soluzione, perlomeno se mi e' permesso gestirla "non in loco" ( ovvero sostituire i suddetti if con altrettanti blocchi "try" non e' la soluzione che propongo io Quote:
|
|||
|
|
|
|
|
#18 | |
|
Senior Member
Iscritto dal: Jan 2001
Città: Milano
Messaggi: 5707
|
Quote:
ho riletto il primo post di Mezzetti, sono io che non ho capito 'na ma**a, non avevo letto il codice :o :o :o comunque la sostanza del mio discorso resta invariata |
|
|
|
|
|
|
#19 | ||
|
Senior Member
Iscritto dal: Apr 2000
Città: Vicino a Montecatini(Pistoia) Moto:Kawasaki Ninja ZX-9R Scudetti: 29
Messaggi: 53971
|
Quote:
Sono d'accordo con kingv...l'eccezione deve essere qualcosa che deve rispecchiare un'anomalia nell'esecuzione del flusso abituale del programma... Un'autentificazione non riuscita non mi sembra affatto un fatto anomalo... Quote:
Perchè non faro al di fuori dell'oggetto ? Beh...dipende dal contesto... Se l'autentificazione è logicamente parte integrante dell'oggetto (ad esempio mettiamo che sia una classe di interfacciamento con un DB e che l'autentificazione sia in questo caso la connessione al DB) allora mi sembra logico che il metodo da adottare sia quello postato (soprattutto per poter riusare al meglio la classe)... |
||
|
|
|
|
|
#20 |
|
Senior Member
Iscritto dal: Dec 2001
Messaggi: 428
|
Secondo me le eccezioni dovrebbero essere usate sempre per gestire qualunque situazione non nominale.
Nel caso in questione si chiedeva di negare la creazione di un oggetto qualora non fossero verificate certe condizioni. Se il costruttore lanciasse una eccezione, il ramo di codice che doveva usare l'eventuale oggetto viene terminato senza dover fare alcun check del tipo: if (p!=NULL) .... else ... In programmi di grande dimensione si risparmia una gran quantita' di codice di error handling. Inoltre, spesso, ci si dimentica di fare questo tipo di check e a run time possiamo avere dei crash inattesi. In questo caso (se si usasse il C++), inoltre, usando l'eccezione possiamo anche evitare l'allocazione dinamica dell'oggetto (che spesso ci si dimentica di deallocare). Infatti non essendo abbligati a tornare un NULL per dire che la creazione e' fallita, possiamo usare l'oggetto come un tipo qualunque: .... Servizi servizio(user, passwd); .... // qui' ci arriviamo sole se il check e' superato. Ciao a tutti.
__________________
PC: Phenom 2 955, 4 GB RAM DDR3, 2 x ATI HD 7870 Ghz edition |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 11:30.



















