Overriding
È possibile l’overloading di funzioni ereditate public class B {//CLASSE BASE public void f(int i) {…} } public class D extends B { //CLASSE DERIVATA public void f(String s) {…} } D d = new D(); d.f(1); //OK: invoca B.f(int) d.f(“prova”); //OK: invoca D.f(String)
Overriding di funzioni Nella classe derivata è possibile anche fare overriding (ridefinizione) delle funzioni della classe base… …definendo nella classe derivata una funzione con esattamente lo stessa segnatura della funzione ereditata…
Overriding di funzioni …ogni volta che si invoca detta funzione su un oggetto della classe derivata (indipendentemente dal tipo del riferimento usato)… …viene eseguito il corpo della funzione ridefinita.
Esempi Esempio1.java Esempio2.java
Osservazioni I clienti della classe D non possono più invocare B.f(int) ma solo D.f(int)… …all’interno della classe invece si può invocare B.f(int) facendo uso di super (analogo a this).
Late Binding
Late binding A tempo di compilazione si controlla solo l’esistenza di una funzione con la segnatura richiesta… …ma non si creano collegamenti con il corpo della funzione stessa…
Late binding …tali collegamenti sono stabiliti a runtime in base alla classe dell’oggetto di invocazione (e non del riferimento). Esempio: LateBinding.java
Note sull’overriding È possibile cambiare il livello di accesso della funzione ridefinita, ma solo allargandolo. È possibile bloccare l’overriding di una funzione qualificandola final.
L’overriding di campi dati non esiste! Se nella classe derivata definiamo un campo dati con lo stesso nome di un campo dati della classe base…
L’overriding di campi dati non esiste! …il campo della classe derivata nasconde quello della classe base… …che però resta accessibile utilizzando riferimenti del tipo base. Esempio: SovrascritturaCampiDati.java
Classi Astratte
Le classi astratte … sono classi che non possono avere istanze proprie … … cioè, sono classi utilizzate per derivare sottoclassi …
Le classi astratte …possono avere funzioni astratte cioè dichiarate ma non definite (la segnatura è presente, ma il corpo no)… …le classi (concrete) derivate devono fare overriding delle funzioni astratte.
Esempio Scrivere una classe Java per rappresentare figure. Per ciascuna figura ci interessa sapere il colore, il perimetro e l’area Figure.java
Esempio Scrivere una classe per rappresentare figure che sono rettangoli, triangoli, cerchi Rettangolo.java, Triangolo.java, Cerchio.java
Esempio di cliente di una classe astratta Scrivere una funzione cliente che dato un array di figure, restituisca la somma dei perimetri ServiziFigure.java
Osservazioni La funzione è polimorfa… …per supportare il polimorfismo l’overriding e il late binding è essenziale… …facilita notevolmente la legibilità, il riuso e l’estendibilità.
Interfacce
Una interfaccia …è una astrazione per un insieme di funzioni pubbliche, delle quali si definisce la segnatura ma non il corpo… …una classe implementa l’interfaccia definendo tutte le funzioni previste dalla stessa.
Sintatticamente … …una interfaccia è simile ad una classe dove… …non possono essere presenti campi dati (eccetto costanti statiche…)… …tutte le funzioni sono astratte (segnatura, ma non corpo)…
Esempio public interface Confrontabile { boolean maggiore(Confrontabile c); boolean paritetico(Confrontabile c); } //Nota: le funzioni di una interfaccia //sono implicitamente public
Data una interfaccia possiamo costruire classi che la implementano … Persona.java Edificio.java
Data una interfaccia possiamo costruire funzioni (polimorfe) che la usano … ServiziCofrontabile.java Main.java
Osservazioni Le interfacce rappresentano collezioni di funzionalità… …messe a disposizione dalle classi che le implementano...
Osservazioni …sfruttando il polimorfismo, possiamo costruire clienti che fanno uso di dette funzionalità, indipendentemente da come sono implementate (riuso)
Differenza tre interfacce e classi astratte …una classe astratta è una classe, cioè una astrazione di un insieme di oggetti simili (quelli delle sue sottoclassi)… …una interfaccia è una semplice astrazione di un insieme di funzionalità...
Differenza tre interfacce e classi astratte …pensare Confrontabile come una astrazione sia delle persone che degli edifici solo perché entrambi dispongono delle funzionalità di confronto maggiore() e paritetico() è una forzatura.
Altre caratteristiche delle interfacce Java
Una classe può implementare più di una interfaccia… public interface I { void g(); } public interface J { void h(); } public class C implements I,J { void g(){…} void h(){…} }
Una interfaccia può essere derivata da un’altra interfaccia… public interface I { void g(); } public interface J extends I {void h();} public class C implements J { void g(){…} void h(){…} }
Java supporta ereditarietà multipla per le interfacce (non per le classi)… public interface I {void g();} public interface J {void h();} public interface M extends I,J {void k();} public class C implements M { void g(){…} void h(){…} void k(){…} }