java设计模式之strategy(策略模式)和policy模式(泛化的strategy模式)

本文详细介绍了Java中的策略模式和策略族模式(Policy),阐述了两者的区别和应用场景。通过具体代码示例展示了如何在实际开发中运用这两种模式,以实现算法的灵活选择和状态处理。策略模式主要用于处理算法的动态切换,而策略族模式则用于应对多方法独立变化的情况。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

strategy模式

 

定义: 运行时刻选择算法

 

表面上看起来,state模式和strategy模式是非常相似的,但既然他们分成两种不同的模式,就有一定的区别,用一句话来概括就是:

策略用来处理算法方式变化,而状态则是处理状态变化。

具体可以参考:http://blog.youkuaiyun.com/lwzcjd/archive/2009/05/19/4201828.aspx

 

下面举个strategy的例子:


 

运行结果:

Called ConcreteStrategyA.algorithmInterface()
Called ConcreteStrategyB.algorithmInterface()
Called ConcreteStrategyC.algorithmInterface()

 

 

policy模式

尽管 GoF 说Policy 模式只是Strategy 模式的一个别名,但是他们给出的Strategy 模式的例子隐含的假定了strategy 对象只使用一个方法――也就是说假定你已经把可能变化的算法拆成了一段单独的代码。

 

其他人用Policy 模式来表示一个对象有多个方法的情况,对于不同的类,这些方法可能相互独立变化。相对于(Strategy 模式) 只能有一个方法而言,Policy 模式具有更大的灵活性。

 

例如,当某个产品需要被运送到不同国家的时候,与该产品相关的海运政策(shipping policy)可以被用来说明一些与运输有关的问题。这些问题可能包括运输方式,如何计算邮资或者运费,客户需求以及费用,特殊处理的费用等等。所有这些东西可能会互不相干的变化,而且很重要的一点是在运输过程中你可能会在不同地点(points)需要上述信息。

 

通常情况下,把Strategy 模式和Policy 模式区别开来是很有好处的,用Strategy 模式处理一个方法(变化)的情况,而用Policy 模式处理多个方法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值