Ciao,
praticamente voglio creare un tipo di dati che implementi collezioni OMOGENEE e dinamica di oggetti distanziabili.
Per OMOGENEA intendo che tutti gli oggetti nella collezione devono avere lo stesso tipo effettivo. Mentre quando dico che gli oggetti devono essere distanziabili intendo dire che devono saper calcolare la propria distanza da oggetti aventi lo stesso tipo effettivo....ma il compilatore mi dà un errore che non capisco
1) Per prima cosa ho implementato un'interface che definisce cos'è un oggetto distanziabile:
2) Poi definisco una collezione omogenea di generici elementi distanziabili tra loro che chiamo CollDiDistanziabili, tale classe permette di creare collezioni dinamiche di oggetti distanziabili, contiene un iteratore e permette di inserire nuovi elementi nella collezione controllando che il loro tipo sia coerente con eventuali altri oggetti già inseriti nellacollezione:codice:public interface Distanziabile{ double dista(Distanziabile d); // Ogni elemento deve essere capace di calcolare la sua distanza da altri elementi }
e fin quì tutto ok credo...codice:import java.util.*; /** OVERVIEW: La classe rappresenta una collezione omogenea e dinamica di oggetti generici distanziabili tra di loro */ public class CollDiDistanziabili{ private Vector V; // La collezione viene rappresentata mediante un Vector /** EFFETCTS: Crea una nuova collezione vuota di oggetti tra loro distanziabili @param: void @return: Il riferimento ad un oggetto di tipo CollDiDistanziabili */ public CollDiDistanziabili(){ V = new Vector(); // Crea la collezione vuota } /** EFFECTS: Se la collezione è vuota, il parametro viene inserito come primo elemento della collezione; Se invece la collezione non è vuota, prima di inserire il parametro nella collezione viene controllato se questo è omogeneo con il tipo degli elementi presenti nella collezione, se lo è allora il parametro viene inserito nella collezione mentre se non lo è viene sollevata una FailureException() MODIFIES: this @param: Il riferimento ad un oggetto di tipo Distanziabile @return: void */ public void addDistanziabile(Distanziabile d){ if(V.size() == 0) V.addElement(d); // Se la collezione è vuota, il parametro viene inserito nella prima posizione else{ // Se invece la lista non è vuota bisogna controllare che il parametro sia omogeneo con gli altri elementi if(V.elementAt(0).getClass().isInstance(d)) // Se il tipo del primo elemento è lo stesso del parametro d V.addElement(d); // allora inserisci d nella collezione else throw new FailureException(); // Se invece non lo è solleva una FailureException } } private class MioIteratore implements Iterator{ // E' la classe interna che implementa l'interfaccia Iterator private int dove; // Variabile che indica dove ci si trova all'interno della collezione durante l'iterazione public MioIteratore(){ // Costruttore del generatore dove = 0; // Imposto la variabile dove a 0 per far iniziare l'iterazione dal primo elemento della collezione } public Object next(){ return V.elementAt(dove); // Ritorna l'elemento corrente nella collezione } public boolean hasNext(){ return dove < V.size(); // Se dove non è l'ultimo elemento della collezione risponde true, altrimenti false } public void remove(){ dove ++; // Rimuove l'elemento dall'iteratore (non dalla collezione) spostando dove al successivo elemento } } public Iterator enumera(){ // Maschero l'implementazione di MioIterator usando un metodo enumera return new MioIteratore(); } }
3) Il problema mi si pone quando vado a realizzare una classe IntPosDistanziabile che implentando l'interface Distanziabile rappresenta numeri interi positivi tra di loro distanziabili (dover per distanziabili si intende la distanza tra 2 interi, ad esempio 3 ed 1 hanno distanza 2 tra loro)
Quando provo a compilare questa classe mi dà questo messaggio di errore che non capisco da cosa dipenda:codice:/** OVERVIEW: La classe rappresenta interi positivi distanziabili, cioè che implementino l'interface Distanziabile e che quindi siano in grado di calcolare la distanza da altri elementi aventi lo stesso tipo effettivo */ public class IntPosDistanziabile implements Distanziabile{ int n; // Variabile di istanza che contiene lo stato dell'ogggetto /** EFFECTS: E' il costruttore, costruisce un nuovo oggetti di tipo IntPosDistanziabile incartanto un valore intero ricevuto come parametro dentro un oggetto di tipo IntPosDistanziabile; Se il parametro è positivo viene creato l'oggetto, altrimenti viene lanciata una ParametroNonValidoException @param: Un int @return: Il riferimento ad un oggetto di tipo IntPosDistanziabile */ public IntPosDistanziabile(int i){ if(i >= 0) n = i; // Se i è un parametro valido viene assegnato tale valore alla variabile di istanza else throw new ParametroNonTrovatoException(); // altrimenti solleva una ParametroNonTrovatoException } /** EFFECTS: Dice quanto l'oggetto ricevente dista dall'oggetto parametro @param: Il riferimento ad un oggetto di tipo IntPosDistanziabile @return: un valore int */ public int dista(IntPosDistanziabile d){ int dista; int differenza = Math.abs(this.n - d.n); return dista; } }
C:\Programmi\Crimson Editor\template\esercizi\esami\09-06-08>javac IntPosDistanziabile.java
IntPosDistanziabile.java:4: IntPosDistanziabile is not abstract and does not override abstract method dista(Distanziabile)
in Distanziabile
public class IntPosDistanziabile implements Distanziabile{
^
1 error
Ah i due tipi di eccezioni me li sono definiti io stupidamente in questo modo:
ecodice:public class FailureException extends RuntimeException{ public FailureException(){ super(); } public FailureException(String s){ super(s); } }
Sapete dirmi cos'è che non và? Per favore l'esame si avvicina...codice:public class ParametroNonTrovatoException extends RuntimeException{ public ParametroNonTrovatoException(){ super(); } public ParametroNonTrovatoException(String s){ super(s); } }
Tnx

Rispondi quotando