|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Bannato
Iscritto dal: Mar 2004
Città: Roma
Messaggi: 2688
|
[JAVA] Domande su esercitazione sulle eccezioni
Ciao,
allora oggi ho provato a capire la prima esercitazione risolta messa in linea dalla proff (l'ho rifatta commentando il codice e cercando di capire ben)...però ho qualche dubietto. Praticamente bisogna proggettare: 1) Un tipo di dato Tripla che rappresenta una tripla di interi e che fornisce le sole due operazioni di: acesso in lettura al primo elemento della triplae l'accesso in lettura al rapporto fra il secondo ed il terzo elemento della tripla. 2) Un tipo di dato GraficoFunzione i quali elementi rappresentano un insieme di punti che rappresentano il grafico di una funzione positiva ad una variabile y=f(x). Qualcosa del genere: {(0,f(0)), (1,f(1)),....(n,f(n))} Dal momento che la funzione può contenere asintoti verticali i punti della funzione vengono rappresentati mediante il tipo di dato Tripla con la seguente codifica: Un punto x che non contiene asintoto verticale: (x, f(x), 1) Un punto x che contiene asintoto verticale: (x, 1, 0). Per tale tipo di dato (GraficoFunzione) l'unica operazione da implementare è quella che calcola il massimo tra i punti non asintoto della funzione. Quindi, inizio con l'implementare il tipo di dato Tripla che rappresento banalmente mediante 3 variabili intere ed implementando i 2 metodi. C'è da notare che il metodo che fornisce il rapporto tra il secondo ed il terzo elemento della tripla potrebbe dividere per 0, non voglio che accada ed allora introduco un'eccezione ThirdElementException da sollevare se tale metodo viene invocato su di una tripla con il terzo elemento pari a 0. Codice:
public class Tripla{
/** OVERVIEW: Rappresenta triple di valori interi; le operazioni definite sono la lettura del primo elemento della
tripla e la lettura del rapporto fra il secondo ed il terzo elemento della tripla */
private int a, b, c;
/** COSTRUTTORE: costruisce un oggetto di tipo tripa.
@param x di tipo int: il primo elemento della tripla
@param y di tipo int: il secondo elemento della tripla
@param z di tipo int: il terzo elemento della tripla
@return il riferimento ad un nuovo oggetto di tipo Tripla */
public Tripla(int x, int y, int z){
a = x;
b = y;
c = z;
}
public int getPrimo(){
/** EFFECTS: Accede in lettura al primo elemento di this
@param void
@return: il primo elemento di this */
return a;
}
public double getRapporto() throws ThirdElementException{
/** EFFECTS: Se il secondo elemento di this è diverso da 0 calcola il rapporto del secondo ed il terzo elemento di
this, altrimento solleva un'eccezione di tipo ThirdElementException.
@param void
@return il rapporto fra il secondo ed il terzo elemento di this di tipo double */
double r = 0; // Variabile che conterrà il rapporto inizialmente inizializzata a 0
if(c != 0) r = ((double) b)/c; // Se il terz elemento è diverso da 0 fai la divisione e metti il risultato in r
else throw new ThirdElementException(); // Altrimenti crea e solleva un'eccezione checked.
return r; // Se l'eccezione non è stata sollevata ritorna il risultato calcolato in r
}
}
Codice:
public class ThirdElementException extends Exception{ // E' un'eccezione di tipo checked perchè estende Exception
public ThirdElementException(){ // Costruttore di default
super(); // Invoca semplicemente il costruttore della classe padre Exception
}
public ThirdElementException(String s){ // Costruttore alternativo che prende in input una stringa testuale s
super(s); // ed invoca il costruttore della classe padre Exception passandogli la stringa s
}
}
Però mi pare di aver capito che le eccezioni di tipo checked oltre a doverle listare accanto al nome del metodo devo per forza gestirle in loco...cosa sbaglio? Grazie Andrea |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Mar 2005
Città: Morimondo city
Messaggi: 5491
|
non è che devi gestirle li al momento se no non avrebbe manco senso sollevarla,vanno gestite da qualche parte o risollevate,al massimo nel main,nel caso di un applicazione desktop,e comunque se non lo fai non compila.
edit:il ragionamento giusto è proprio quello di rimandare al contesto superiore il verificarsi di un anomalia,in modo che chi utilizzerà la tua classe avrà modo di gestire questa situazione anomala
__________________
Khelidan |
|
|
|
|
|
#3 | |
|
Senior Member
Iscritto dal: Aug 2005
Città: Wien
Messaggi: 435
|
Quote:
__________________
"Sono 126 miglia per Chicago. Abbiamo il serbatoio pieno, mezzo pacchetto di sigarette, è buio, e portiamo tutt'e due gli occhiali da sole" |
|
|
|
|
|
|
#4 | |
|
Bannato
Iscritto dal: Mar 2004
Città: Roma
Messaggi: 2688
|
Quote:
Se ho dichiarato un'eccezione come checked, in un metodo posso fare 2 cose: 1) La gestisco direttamente dentro il metodo: nel caso di getRapporto potrei sollevare la ThirdElementException e gestirla direttamente in getRapporto come mi pare a me (per esempio dicendo che se si solleva allora la gestisco direttamente nel metodo settando ad 1 il terzo elemento della tripla) e così il metodo ha gestito l'eccezione e prosegue la sua computazione. 2) La sollevo e basta e se la gestisce in qualche modo il chiamante (per esempio il chiamante capisce che quelloè un asintoto ed è stato semplicemente un modo per segnalare una stuazione eccezionale che però non è un errore in questo caso) Capito bene? Grazie Andrea |
|
|
|
|
|
|
#5 |
|
Senior Member
Iscritto dal: Aug 2005
Città: Wien
Messaggi: 435
|
Si anche se il primo caso non andrebbe mai essere utilizzato se sei tu a lanciare l'eccezione nel metodo (new Exception()); come d'altronde ti hanno già detto.
Ciao, Giorgio
__________________
"Sono 126 miglia per Chicago. Abbiamo il serbatoio pieno, mezzo pacchetto di sigarette, è buio, e portiamo tutt'e due gli occhiali da sole" |
|
|
|
|
|
#6 | |
|
Senior Member
Iscritto dal: Mar 2005
Città: Morimondo city
Messaggi: 5491
|
Quote:
__________________
Khelidan |
|
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 02:58.




















