====
1.1、概念
定义一系列的算法,把它们一个个封装起来,并且使它们可以互相替换。本模式使得算法可独立于
使用它的客户而变化。
1.2、使用场景
一个类定义了多种行为,并且这些行为在这个类的方法中以多个条件语句的形式出现,那么可以
使用策略模式避免在类中使用大量的条件语句。
1.3、UML结构图分析
可以看到,策略模式中主要有以下几个角色:
-
Strategy 接口,用于定义算法的固定套路
-
ConcreteStrategyA , ……B , 等具体算法实现类
-
Context 外部调用类
Context 中引用的是 接口,因此当更换具体实现时,Context 不用修改代码,这就是针对接口编程的好处。
1.4、实际代码分析
1.4.1、传统写法:
/**
- 传统写法,如果再增加一个出租车选项,代码还要再写一份,逻辑判断还要在增加一种判断
*/
public class PriceCalculator {
private static final int BUS = 1;
private static final int SUBWAY = 2;
public static void main(String[] args) {
PriceCalculator calculator = new PriceCalculator();
System.out.println(“坐公交车20KM价格:” + calculator.calculatePrice(20, BUS));
System.out.println(“坐地铁20KM价格:” + calculator.calculatePrice(20, SUBWAY));
}
/**
- 公交车计价:10公里之内1块钱,超过十公里每加1块可坐5公里
*/
private int busPrice(int km) {
//超过十公里的距离
int extraTotal = km - 10;
//超过距离是5公里的倍数
int extraFactor = extraTotal / 5;
//超过的距离对5公里取余
int fraction = extraFactor % 5;
//价格计算
int price = 1 + extraFactor % 5;
return fraction > 0 ? ++price : price;
}
/**
- 地铁计价:6公里内3块,6-12公里4块,12-22公里5块,22-32公里6块,其他距离7块
*/
private int subwayPrice(int km) {
if (km <= 6) {
return 3;
} else if (km > 6 && km < 12) {
return 4;
} else if (km > 12 && km < 22) {
return 5;
} else if (km > 22 && km < 32) {
return 6;
}
return 7;
}
/**
- 根据不同类型计算
*/
int calculatePrice(int km, int type) {
if (type == BUS) {
return busPrice(km);
} else if (type == SUBWAY) {
return subwayPrice(km);
}
return 0;
}
}
1.4.2、策略模式写法:
public interface AbstractStrategy {
//按距离来计算价格
int calculatePrice(int km);
}
/**
- 公交车计价:10公里之内1块钱,超过十公里每加1块可坐5公里
*/
public class BusStrategy implements AbstractStrategy {
@Override
public int calculatePrice(int km) {
//超过十公里的距离
int extraTotal = km - 10;
//超过距离是5公里的倍数
int extraFactor = extraTotal / 5;
//超过的距离对5公里取余
int fraction = extraFactor % 5;
//价格计算
int price = 1 + extraFactor % 5;
return fraction > 0 ? ++price : price;
}
}
/**
- 地铁计价:6公里内3块,6-12公里4块,12-22公里5块,22-32公里6块,其他距离7块
*/
public class SubwayStrategy implements AbstractStrategy {
@Override
public int calculatePrice(int km) {
if (km <= 6) {
return 3;
} else if (km > 6 && km < 12) {
return 4;
} else if (km > 12 && km < 22) {
return 5;
} else if (km > 22 && km < 32) {
return 6;
}
return 7;
}
}
public class TaxiStrategy implements AbstractStrategy {
@Override
public int calculatePrice(int km) {
题外话
我们见过很多技术leader在面试的时候,遇到处于迷茫期的大龄程序员,比面试官年龄都大。这些人有一些共同特征:可能工作了7、8年,还是每天重复给业务部门写代码,工作内容的重复性比较高,没有什么技术含量的工作。问到这些人的职业规划时,他们也没有太多想法。
其实30岁到40岁是一个人职业发展的黄金阶段,一定要在业务范围内的扩张,技术广度和深度提升上有自己的计划,才有助于在职业发展上有持续的发展路径,而不至于停滞不前。
不断奔跑,你就知道学习的意义所在!
注意:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题(含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门,即可获取!
所在!
注意:我们之前因为秋招收集的二十套一二线互联网公司Android面试真题(含BAT、小米、华为、美团、滴滴)和我自己整理Android复习笔记(包含Android基础知识点、Android扩展知识点、Android源码解析、设计模式汇总、Gradle知识点、常见算法题汇总。)
[外链图片转存中…(img-6bWnQkW2-1715394366236)]
《Android学习笔记总结+移动架构视频+大厂面试真题+项目实战源码》,点击传送门,即可获取!