java设计模式--策略模式

java设计模式---策略模式

策略模式使用场景

主要是在遇到如何让算法和对象分开来,使得算法可以独立于使用它的客户而变化?
采用策略模式主要思想:
把一个类中经常改变或者将来可能改变的部分提取出来,作为一个接口,然后在类中包含这个对象的实例,这样类的实例在运行时就可以随意调用实现了这个接口的类的行为

例子

专门用于排序的类DataSorter中实现对所有A类、B类....等等进行排序

初步想法

DataSorter.java的代码如下

public class DataSorter {

   /* public static void sort(A a){

    }

    public static void sort(B a){

    }

    public static void sort(C c){

    }*/
    }

基于上面的做法会造成DataSorter的可扩展性差,要支持对新类的排序时,要修改代码

更好的办法

更好的思路是:既然DataSorter是要根据不同的类的采取不同的方法实现排序,那么具体实现排序的方法交由子类去实现,且都实现同一个接口Comparable,那么DataSorter只需对Comparable排序,而无需理会具体要排序的是

类之间的关系

1

具体代码如下:

1.DataSorter

/**
 *目标:专门用于排序的类DataSorter中实现对所有A类、B类....等等进行排序
 * 如果直接在Datasorter中使用对A、B、C类排序这样扩展行差,要支持对新类的排序时,要修改代码
 * Created by td on 2017/8/29.
 * 更好的思路是::既然DataSorter是要根据不同的类的采取不同的方法实现排序,那么具体实现排序的方法交由子类去实现,且都实现同一个接口Comparable,那么DataSorter只需对Comparable排序,而无需理会具体要排序的是
 */
public class DataSorter {
    public static void sort(Comparable [] a) {

        int index;                          //保存每次比较,最大值的下标;

        for(int i = 1; i < a.length; i++){   //控制外循环次数
            index = 0;
            for(int j = 1; j <= a.length - i ; j++){
                if(a[j].compareTo(a[index]) == 1){
                    index = j;
                }
            }
            swap(a, index, a.length -i);
        }
    }


    private static void swap(Comparable[] a, int x, int y) {
        Comparable tmp = a[x];
        a[x] = a[y];
        a[y] = tmp;

    }


    //输出数组元素
    public static void show(Comparable[] a) {
        for(int i = 0; i < a.length; i++){
            System.out.println(a[i]);
        }
    }

   /* public static void sort(A a){

    }

    public static void sort(B a){

    }

    public static void sort(C c){

    }*/

/*
    //冒泡排序法
    //主要思路:按升序排序,数组元素两两比较,大的立即排后面
    public static void bubbleSort(int[] a) {

       for (int i=0;i<a.length;i++){
           int index = i;
           for (int j = i;j<a.length;j++){
               if (a[index]>a[j]){
                   index = j;
               }
           }

           if (index!=i){
               swap(a,i,index);
           }
       }




    }


    //直接选择排序法
    //主要思路:按升序排序,每次循环找出最小数,把他放到第i位置上
    public static void selectSort(int[] array) {

    }


    //交换数组元素
    private static void swap(int[] a, int x, int y) {
        int tmp = a[x];
        a[x] = a[y];
        a[y] = tmp;
    }

    //输出数组元素
    public static void show(int[] a) {
        for(int i = 0; i < a.length; i++){
            System.out.println(a[i]);
        }
    }

    public static void main(String[] args) {
        int[] a = {1,4,0,5,1,2,3,10,9,2};
        bubbleSort(a);
        show(a);
    }
*/

}

2.定义排序接口Comparable

/**
 * Created by td on 2017/8/29.
 */
public interface Comparable<T> {
    public int compareTo(T o);
}

3.定义student并实现Comparable

/**
 * Created by td on 2017/8/29.
 */
public class Student implements Comparable<Student> {

    private int mark;

    public int getMark() {
        return mark;
    }

    public void setMark(int mark) {
        this.mark = mark;
    }

    public Student(int mark) {
        super();
        this.mark = mark;
    }

    @Override
    public String toString() {
        return "student" +mark+" ";
    }

    @Override
    public int compareTo(Student o) {
        if(this.mark > o.getMark()){
            return 1;
        }else if(this.mark == o.getMark()){
            return 0;
        }else{
            return -1;
        }
    }
}

4.定义Teacher并实现Comparable

public class Teacher implements Comparable<Teacher> {
 
    private int title;
     
    public Teacher(int title) {
        super();
        this.title = title;
    }
 
    public int getTitle() {
        return title;
    }
 
    public void setTitle(int title) {
        this.title = title;
    }
 
    @Override
    public int compareTo(Teacher o) {
        if(this.title > o.getTitle()){
            return 1;
        }else if(this.title == o.getTitle()){
            return 0;
        }else{
            return -1;
        }
    }
     
    @Override
    public String toString() {
        return "teacher--" +title+" ";
    }
}
  1. 定义测试类
public class Test {

    public static void main(String[] args) {
        Student[] students = {new Student(10),new Student(5),new Student(100)};
        DataSorter.sort(students);
        DataSorter.show(students);
        System.out.println("----------------------");
        Teacher [] ts = {new Teacher(10),new Teacher(3),new Teacher(12)};
        DataSorter.sort(ts);
        DataSorter.show(ts);
    }
}

6.输出结果

student5 
student10 
student100 
----------------------
teacher--3 
teacher--10 
teacher--12 
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 定义 策略模式属于对象的行为模式。其用意是针对一组算法,将每一个算法封装到具有共同接口的独立的类中,从而使得它们可...
    步积阅读 774评论 0 2
  • 今天给大家说说田忌赛马的故事。如有雷同,纯属巧合!话说在战国时期,群雄割据,硝烟四起,茶余饭后还是少不了娱乐活动的...
    Jet啟思阅读 5,530评论 4 17
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,766评论 18 399
  • 一、定义 策略模式是指对一系列的算法定义,并将每一个算法封装起来,而且使它们还可以相互替换。策略模式让算法独立于使...
    怡红快绿阅读 905评论 0 0
  • "因为我觉得每个男人最开始,都是一颗尘埃。然后有一个女孩子接受了你,对你说了一句我爱你,于是乎尘埃有了力量,他就变...
    冰羯阅读 249评论 0 0