java設(shè)計模式--策略模式

java設(shè)計模式---策略模式

策略模式使用場景

主要是在遇到如何讓算法和對象分開來洲赵,使得算法可以獨立于使用它的客戶而變化?
采用策略模式主要思想:
把一個類中經(jīng)常改變或者將來可能改變的部分提取出來叔收,作為一個接口,然后在類中包含這個對象的實例跨琳,這樣類的實例在運行時就可以隨意調(diào)用實現(xiàn)了這個接口的類的行為

例子

專門用于排序的類DataSorter中實現(xiàn)對所有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是要根據(jù)不同的類的采取不同的方法實現(xiàn)排序窒升,那么具體實現(xiàn)排序的方法交由子類去實現(xiàn),且都實現(xiàn)同一個接口Comparable慕匠,那么DataSorter只需對Comparable排序饱须,而無需理會具體要排序的是

類之間的關(guān)系

1

具體代碼如下:

1.DataSorter

/**
 *目標:專門用于排序的類DataSorter中實現(xiàn)對所有A類、B類....等等進行排序
 * 如果直接在Datasorter中使用對A台谊、B蓉媳、C類排序這樣擴展行差,要支持對新類的排序時,要修改代碼
 * Created by td on 2017/8/29.
 * 更好的思路是::既然DataSorter是要根據(jù)不同的類的采取不同的方法實現(xiàn)排序锅铅,那么具體實現(xiàn)排序的方法交由子類去實現(xiàn)酪呻,且都實現(xiàn)同一個接口Comparable,那么DataSorter只需對Comparable排序盐须,而無需理會具體要排序的是
 */
public class DataSorter {
    public static void sort(Comparable [] a) {

        int index;                          //保存每次比較,最大值的下標;

        for(int i = 1; i < a.length; i++){   //控制外循環(huán)次數(shù)
            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;

    }


    //輸出數(shù)組元素
    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){

    }*/

/*
    //冒泡排序法
    //主要思路:按升序排序玩荠,數(shù)組元素兩兩比較,大的立即排后面
    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);
           }
       }




    }


    //直接選擇排序法
    //主要思路:按升序排序贼邓,每次循環(huán)找出最小數(shù)阶冈,把他放到第i位置上
    public static void selectSort(int[] array) {

    }


    //交換數(shù)組元素
    private static void swap(int[] a, int x, int y) {
        int tmp = a[x];
        a[x] = a[y];
        a[y] = tmp;
    }

    //輸出數(shù)組元素
    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并實現(xiàn)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并實現(xiàn)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.輸出結(jié)果

student5 
student10 
student100 
----------------------
teacher--3 
teacher--10 
teacher--12 
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市塑径,隨后出現(xiàn)的幾起案子女坑,更是在濱河造成了極大的恐慌,老刑警劉巖晓勇,帶你破解...
    沈念sama閱讀 218,941評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件堂飞,死亡現(xiàn)場離奇詭異,居然都是意外死亡绑咱,警方通過查閱死者的電腦和手機绰筛,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來描融,“玉大人铝噩,你說我怎么就攤上這事×耍” “怎么了骏庸?”我有些...
    開封第一講書人閱讀 165,345評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長年叮。 經(jīng)常有香客問我具被,道長,這世上最難降的妖魔是什么只损? 我笑而不...
    開封第一講書人閱讀 58,851評論 1 295
  • 正文 為了忘掉前任一姿,我火速辦了婚禮,結(jié)果婚禮上跃惫,老公的妹妹穿的比我還像新娘叮叹。我一直安慰自己,他們只是感情好爆存,可當我...
    茶點故事閱讀 67,868評論 6 392
  • 文/花漫 我一把揭開白布蛉顽。 她就那樣靜靜地躺著,像睡著了一般先较。 火紅的嫁衣襯著肌膚如雪携冤。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,688評論 1 305
  • 那天闲勺,我揣著相機與錄音噪叙,去河邊找鬼。 笑死霉翔,一個胖子當著我的面吹牛睁蕾,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播债朵,決...
    沈念sama閱讀 40,414評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼子眶,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了序芦?” 一聲冷哼從身側(cè)響起臭杰,我...
    開封第一講書人閱讀 39,319評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎谚中,沒想到半個月后渴杆,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體寥枝,經(jīng)...
    沈念sama閱讀 45,775評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年磁奖,在試婚紗的時候發(fā)現(xiàn)自己被綠了囊拜。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,096評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡比搭,死狀恐怖冠跷,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情身诺,我是刑警寧澤蜜托,帶...
    沈念sama閱讀 35,789評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站霉赡,受9級特大地震影響橄务,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜穴亏,卻給世界環(huán)境...
    茶點故事閱讀 41,437評論 3 331
  • 文/蒙蒙 一仪糖、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧迫肖,春花似錦锅劝、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至隅津,卻和暖如春诬垂,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背伦仍。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評論 1 271
  • 我被黑心中介騙來泰國打工结窘, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人充蓝。 一個月前我還...
    沈念sama閱讀 48,308評論 3 372
  • 正文 我出身青樓隧枫,卻偏偏與公主長得像,于是被迫代替她去往敵國和親谓苟。 傳聞我的和親對象是個殘疾皇子官脓,可洞房花燭夜當晚...
    茶點故事閱讀 45,037評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 定義 策略模式屬于對象的行為模式。其用意是針對一組算法涝焙,將每一個算法封裝到具有共同接口的獨立的類中卑笨,從而使得它們可...
    步積閱讀 767評論 0 2
  • 今天給大家說說田忌賽馬的故事。如有雷同仑撞,純屬巧合赤兴!話說在戰(zhàn)國時期妖滔,群雄割據(jù),硝煙四起桶良,茶余飯后還是少不了娛樂活動的...
    Jet啟思閱讀 5,507評論 4 17
  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法座舍,類相關(guān)的語法,內(nèi)部類的語法艺普,繼承相關(guān)的語法簸州,異常的語法鉴竭,線程的語...
    子非魚_t_閱讀 31,639評論 18 399
  • 一歧譬、定義 策略模式是指對一系列的算法定義,并將每一個算法封裝起來搏存,而且使它們還可以相互替換瑰步。策略模式讓算法獨立于使...
    怡紅快綠閱讀 883評論 0 0
  • "因為我覺得每個男人最開始,都是一顆塵埃璧眠。然后有一個女孩子接受了你缩焦,對你說了一句我愛你,于是乎塵埃有了力量责静,他就變...
    冰羯閱讀 232評論 0 0