策略模式(Strategy):它定義了算法家族,分別封裝起來,讓它們之間能夠互相替換,此模式讓算法的變化,不會影響到使用算法的客戶。php
/** * Strategy.php(策略類) * Class Strategy */ abstract class Strategy { /** * 算法方法 */ abstract public function doInterface(); } /** * ConcreteStrategyA.php(具體策略類) * Class ConcreteStrategyA */ class ConcreteStrategyA extends Strategy { /** * 算法A具體實現方法 */ public function doInterface() { // TODO: Implement doInterface() method. return "使用算法A\n"; } } /** * ConcreteStrategyB.php(具體策略類) * Class ConcreteStrategyB */ class ConcreteStrategyB extends Strategy { /** * 算法B具體實現方法 */ public function doInterface() { // TODO: Implement doInterface() method. return "使用算法B\n"; } } /** * Class Context */ class Context { private $strategy; public function __construct(Strategy $strategy) { $this->strategy = $strategy; } /** * 根據具體的策略對象,調用相應的算法的方法 */ public function getInterface() { return $this->strategy->doInterface(); } }
客戶端調用:算法
// 算法A $strategyA = new Context(new ConcreteStrategyA()); echo $strategyA->getInterface(); echo '<br>'; // 算法B $strategyB = new Context(new ConcreteStrategyB()); echo $strategyB->getInterface();
結果:this
使用算法A
使用算法B