Abstraktní třídy Motivace • Java disponuje rozhraními. • Pak máme třídu(y) implementující určité rozhraní. • Někdy je vhodné určité rozhraní implementovat pouze částečně: ◦ Rozhraní = Specifikace ◦ Abstraktní třída = Částečná implementace rozhraní (stačí mít hotové některé metody) a současně předek konkrétních tříd, tedy plných implementací ◦ Neabstraktní třída = Úplná implementace rozhraní (musí mít hotové všechny metody) Zápis abstraktní třídy • Abstraktní třída je označena klíčovým slovem abstract v hlavičce, např.: public abstract class AbstractSearcher • Název začínající na Abstract není povinný ani nutný. • Abstraktní třída má obvykle alespoň jednu abstraktní metodu, deklarovanou např.: public abstract int indexOf(double d); • Od abstraktní třídy nelze vytvořit instanci, (chybí implementace některých metod) nelze napsat např.: Searcher ch = new AbstractSearcher(...); Reálný příklad: rozhraní → abstraktní třída → neabstraktní třída • Searcher = rozhraní — specifikuje, co má prohledávač umět • AbstractSearcher = abstraktní třída — předek konkrétních plných implementací prohledávače • LinearSearcher = konkrétní třída — plná implementace prohledávače 1 Searcher Searcher je rozhraní = specifikuje, co má prohledávač umět public interface Searcher {   // Set the array for later searching   void setData(double[] a);   // Check whether array contains d element   boolean contains(double d);   // Return the position of d in the array (or -1 if not found)   int indexOf(double d); } AbstractSearcher AbstractSearcher je abstraktní třída = předek konkrétních plných implementací prohledávače // this class implements Searcher only partially public abstract class AbstractSearcher implements Searcher {   // array, its getters and setters are implemented   private double[] array;   public void setData(double[] a) { array = a; }   public double[] getData() { return array; }   // we can call indexOf now - it will be implemented leter   public boolean contains(double d) {   return indexOf(d) >= 0;   }   // finding the position of d is NOT implemented yet!   public abstract int indexOf(double d); } LinearSearcher LinearSearcher je konkrétní třída = plná implementace prohledávače, pomocí lineárního prohledání 2 public class LinearSearcher extends AbstractSearcher {   // class has to implement all abstract methods   public int indexOf(double d) {   double[] data = getData();   for(int i = 0; i < data.length; i++) {   if(data[i] == d) {   return i;   }   }   return -1;   } } Repl.it demo k abstraktním třídám • https://repl.it/@tpitner/PB162-Java-Lecture-06-abstract-classes 3