定义一系列算法,把它们一个个封装起来,并且使他们可以相互替换。
通俗的讲,实现同一个功能,有多种方法或策略。可以把这些方法或策略提取并封装起来。需要使用哪种方法,传对应的对象进来就行。
1)定义一个策略接口,该接口定义若干抽象方法。
2)具体策略,实现策略接口,并实现接口中定义的方法。
3)封装调用类,持有策略接口的引用。当用户需要完成某项功能时,只需向这个类传入相应的策略对象,并调用方法即可。
以文件的加密解密为例做说明。
1)策略接口,定义策略名
/** * 策略接口 */ public interface EncodeStrategy { /** * 加密算法 * @param file */ public abstract void encryptFile(File file); /** * 解密算法 * @param file * @return */ public abstract String decryptFile(File file); }
2)具体策略类1
/** * 具体策略 */ public class AESEncode implements EncodeStrategy { @Override public void encryptFile(File file) { //省略具体细节 } @Override public String decryptFile(File file) { //省略具体细节 return null; } }
具体策略类2
public class Base64Encode implements EncodeStrategy { @Override public void encryptFile(File file) { //省略具体细节 } @Override public String decryptFile(File file) { //省略具体细节 return null; } }
3)封装调用类
/** * 封装调用类,需要用到具体策略,只需传入其对象即可 */ public class FileEncode{ /** * 策略接口的引用 */ EncodeStrategy strategy; public FileEncode(EncodeStrategy strategy){ this.strategy = strategy; } //根据传入的具体策略对象,调用其方法 public void encryptFile(File file) { strategy.encryptFile(file); } //根据传入的具体策略对象,调用其方法 public String decryptFile(File file) { return strategy.decryptFile(file); } }
4)测试代码
public class TestStrategy { public static void main(String args []){ File file = new File("d:\test.txt"); //调用策略1 实现加密 FileEncode fileEncode = new FileEncode(new AESEncode()); fileEncode.encryptFile(file); //调用策略2 实现加密 fileEncode = new FileEncode(new Base64Encode()); fileEncode.encryptFile(file); } }
以上是Java设计模式:策略模式及实现方法详解的详细内容。更多信息请关注PHP中文网其他相关文章!