定义
策略模式定义了一系列的算法,并将每一个算法封装起来,而且使他们还可以相互替换。策略模式让算法独立于使用它的客户而独立变化。
Android 源码中使用策略模式
时间插值器(TimeInterpolator)
特点
优点:
1.结构清晰明了、使用简单直观。
2.耦合度相对而言较低,扩展方便。
3.操作封装也更为彻底,数据更为安全。缺点:
1.随着策略的增加,子类也会变得繁多。
使用场景
- 针对同一类型问题的多种处理方式,仅仅是具体行为有差别时。
- 需要安全地封装多种同一类型的操作时。
- 出现同一抽象类有多个子类,而又需要使用if-else或者switch-case来选择具体子类时。
简单实现
需求:计算图书价格,初级会员没有折扣,中级会员打9折,高级会员打8折。如果一般写法,应该是if-else判断他是什么级别的会员,在计算相应的折扣。下面使用策略模式来进行实现。
折扣接口:
public interface MemberStrategy {
double calcPrice(double booksPrice);
}
初级会员折扣类:
public class PrimaryMemberStrategy implements MemberStrategy {
@Override
public double calcPrice(double booksPrice) {
Log.d("TAG", "初级会员没有折扣噢");
return booksPrice;
}
}
中级会员折扣类:
public class IntermediateMemberStrategy implements MemberStrategy {
@Override
public double calcPrice(double booksPrice) {
Log.d("TAG", "中级会员的折扣为9折");
return booksPrice * 0.9;
}
}
高级会员折扣类:
public class AdvancedMemberStrategy implements MemberStrategy {
@Override
public double calcPrice(double booksPrice) {
Log.d("TAG", "高级会员的折扣为8折");
return booksPrice * 0.8;
}
}
价格类:
public class Price {
private MemberStrategy mStrategy;
public Price(MemberStrategy strategy) {
mStrategy = strategy;
}
public double quote(double booksPrice) {
return this.mStrategy.calcPrice(booksPrice);
}
}
使用:
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initData();
}
private void initData() {
MemberStrategy strategy = new AdvancedMemberStrategy();
Price price = new Price(strategy);
double quote = price.quote(500);
Log.d("TAG", "高级会员的最终价格为:" + quote);
}
}
结果:
高级会员的折扣为8折
高级会员的最终价格为:400.0