Şablon Deseni:
Şablon yöntemi, alt sınıfların, temel sınıfta tanımlanan algoritmanın ana yapısını ve adımlarını değiştirmeden algoritmanın belirli adımlarını yeniden tanımlamasına izin vermekle ilgilidir. Şablon kalıbı genellikle kalıtım kullanır, bu nedenle alt sınıfın gerekirse geçersiz kılmayı seçebileceği temel sınıfta genel bir algoritma uygulaması sağlanabilir.
public abstract class RobotTemplate {
/* This method can be overridden by a subclass if required */
public void start() {
System.out.println("Starting....");
}
/* This method can be overridden by a subclass if required */
public void getParts() {
System.out.println("Getting parts....");
}
/* This method can be overridden by a subclass if required */
public void assemble() {
System.out.println("Assembling....");
}
/* This method can be overridden by a subclass if required */
public void test() {
System.out.println("Testing....");
}
/* This method can be overridden by a subclass if required */
public void stop() {
System.out.println("Stopping....");
}
/*
* Template algorithm method made up of multiple steps, whose structure and
* order of steps will not be changed by subclasses.
*/
public final void go() {
start();
getParts();
assemble();
test();
stop();
}
}
/* Concrete subclass overrides template step methods as required for its use */
public class CookieRobot extends RobotTemplate {
private String name;
public CookieRobot(String n) {
name = n;
}
@Override
public void getParts() {
System.out.println("Getting a flour and sugar....");
}
@Override
public void assemble() {
System.out.println("Baking a cookie....");
}
@Override
public void test() {
System.out.println("Crunching a cookie....");
}
public String getName() {
return name;
}
}
Yukarıdaki kodda, go () algoritması adımlarının her zaman aynı olacağına dikkat edin, ancak alt sınıflar belirli bir adımı gerçekleştirmek için farklı bir tarif tanımlayabilir.
Strateji Düzeni:
Strateji modeli, istemcinin çalışma zamanında somut algoritmalar uygulamasını seçmesine izin vermekle ilgilidir. Tüm algoritmalar izole ve bağımsızdır, ancak ortak bir arayüz uygular ve algoritma içindeki belirli adımları tanımlama fikri yoktur.
/**
* This Strategy interface is implemented by all concrete objects representing an
* algorithm(strategy), which lets us define a family of algorithms.
*/
public interface Logging {
void write(String message);
}
/**
* Concrete strategy class representing a particular algorithm.
*/
public class ConsoleLogging implements Logging {
@Override
public void write(String message) {
System.out.println(message);
}
}
/**
* Concrete strategy class representing a particular algorithm.
*/
public class FileLogging implements Logging {
private final File toWrite;
public FileLogging(final File toWrite) {
this.toWrite = toWrite;
}
@Override
public void write(String message) {
try {
final FileWriter fos = new FileWriter(toWrite);
fos.write(message);
fos.close();
} catch (IOException e) {
System.out.println(e);
}
}
}
Tam kaynak kodu için github veri havuzuma göz atın .