public abstract class AbstractSearcher
Někdy je vhodné určité rozhraní implementovat pouze částečně:
abstract
v hlavičce, např.:public abstract class AbstractSearcher
Abstract
není povinný ani nutný.public abstract int indexOf(double d);
Searcher ch = new AbstractSearcher(...);
Searcher
= rozhraní — specifikuje, co má prohledávač umětAbstractSearcher
= abstraktní třída — předek konkrétních plných implementací prohledávačeLinearSearcher
= konkrétní třída — plná implementace prohledávačeSearcher
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
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
je konkrétní třída = plná implementace prohledávače, pomocí lineárního prohledání
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;
}
}
/