php实现策略模式

PHP设计模式之策略模式

策略模式作为一种软件设计模式,指对象有某个行为,但是在不同的场景中,该行为有不同的实现算法。比如每个人都要“交个人所得税”,但是“在美国交个人所得税”和“在中国交个人所得税”就有不同的算税方法。

策略模式图

策略模式:

  • 定义了一组算法(业务规则);
  • 封装了每个算法;
  • 这族的算法可互换代替(interchangeable)。

组成

—抽象策略角色: 策略类,通常由一个接口或者抽象类实现。
—具体策略角色:包装了相关的算法和行为。
—环境角色:持有一个策略类的引用,最终给客户端调用。

PHP实现策略模式

<?php

// 抽象活动算法类
abstract class  StrategyAbstract
{
    public abstract function discount($price);
}

//满减活动算法类
class   FullReductionStrategy extends StrategyAbstract
{

    public function discount($price)
    {
        echo '我是满减算法';
}
    }

//满折活动算法类
class FullDiscountStrategy extends StrategyAbstract
{
    public function discount($price)
    {
        echo '我是满折算法';
    }

}

//满赠活动算法类
class FullGrantStrategy extends StrategyAbstract
{
    public function discount($price)
    {
        echo '我是满赠算法';
    }

}
//策略工厂
class StrategyFactory
{
    private $strategy;

    public function __construct($strategy)
    {
        $this->strategy =  $strategy;
    }
    public function getDiscount($money)
    {
        $this->strategy->discount($money);
    }
}
    $strategy1 = new StrategyFactory(new FullReductionStrategy());
    $strategy1->getDiscount(1000);
    $strategy2 = new StrategyFactory(new FullDiscountStrategy());
    $strategy2->getDiscount(2000);
    $strategy3 = new StrategyFactory(new FullGrantStrategy());
    $strategy3->getDiscount(1500);

使用场景

  1. 如果在一个系统里面有许多类,它们之间的区别仅在于它们的行为,那么使用策略模式可以动态地让一个对象在许多行为中选择一种行为。
  2. 一个系统需要动态地在几种算法中选择一种。
  3. 如果一个对象有很多的行为,如果不用恰当的模式,这些行为就只好使用多重的条件选择语句来实现。
    注意事项: 如果一个系统的策略多于四个,就需要考虑使用混合模式,解决策略类膨胀的问题。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
策略模式是一种常见的设计模式,可以在 PHP 中很容易地实现策略模式的核心思想是将算法封装成一个个独立的策略,然后在运行时根据不同的情况选择不同的策略。这样可以使得算法的变化独立于使用算法的客户端,提高代码的可维护性和扩展性。 下面是一个 PHP 中的策略模式的例子: ```php // 定义策略接口 interface PaymentStrategy { public function pay($amount); } // 实现不同的策略 class CreditCardStrategy implements PaymentStrategy { public function pay($amount) { echo "Paid $amount via Credit Card."; } } class PaypalStrategy implements PaymentStrategy { public function pay($amount) { echo "Paid $amount via Paypal."; } } // 使用策略 class PaymentContext { private $strategy; public function __construct(PaymentStrategy $strategy) { $this->strategy = $strategy; } public function executeStrategy($amount) { $this->strategy->pay($amount); } } // 示例代码 $cc = new CreditCardStrategy(); $paypal = new PaypalStrategy(); $payment = new PaymentContext($cc); $payment->executeStrategy(100); $payment = new PaymentContext($paypal); $payment->executeStrategy(200); ``` 在这个例子中,我们定义了一个 `PaymentStrategy` 接口,包含了一个 `pay()` 方法,然后实现了两个不同的策略 `CreditCardStrategy` 和 `PaypalStrategy`。最后,我们使用 `PaymentContext` 来执行不同的策略。 这个例子很简单,但是可以看到策略模式的优点:算法的变化独立于客户端代码,我们可以轻松地增加、删除或修改不同的策略,而不需要修改客户端代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值