The NoteBook of EricKong

            BlogJava :: 首頁 :: 聯系 :: 聚合  :: 管理
            611 Posts :: 1 Stories :: 190 Comments :: 0 Trackbacks

          說到現在,讀者應該對Comparable接口有了大概的了解,但是為什么又要有一個Comparator接口呢?難道Java的開發(fā)者都吃飽撐著沒事做嗎?

          再談Comparator接口之前,大家應該先了解一個叫“策略模式”的東東。一下是百度百科對策略模式的描寫:

          策略模式定義了一系列的算法,并將每一個算法封裝起來,而且使它們還可以相互替換。策略模式讓算法獨立于使用它的客戶而獨立變化。(原文:The Strategy Pattern defines a family of algorithms,encapsulates each one,and makes them interchangeable. Strategy lets the algorithm vary independently from clients that use it.)

           

          之所以要談到策略模式,就是因為Comparator接口其實就是一種策略模式的實踐。實現Comparator接口的類必然就會實現一個compareTo(Object o1, Object o2)的方法,而這個方法就是算法中的一部分,所有使用了compareTo方法的類都不會關心compareTo是如何工作的,只關心他的返回值,這也是面向對象中著名的封裝特性。

          那Comparator接口應該如何使用呢?別急,首先我們要先對Person類進行一下處理,因為我們現在使用Comparator接口,所以Comparable接口就可以光榮的退休了:

             1: public class Person {
             2:  
             3:     private String name;
             4:     private int age;
             5:     
             6:     public Person() {
             7:         
             8:     }
             9:     
            10:     public Person(String name, int age) {
            11:         this.name = name;
            12:         this.age = age;
            13:     }
            14:  
            15:     public String getName() {
            16:         return name;
            17:     }
            18:  
            19:     public void setName(String name) {
            20:         this.name = name;
            21:     }
            22:  
            23:     public int getAge() {
            24:         return age;
            25:     }
            26:  
            27:     public void setAge(int age) {
            28:         this.age = age;
            29:     }
            30:  
            31:     @Override
            32:     public String toString() {
            33:         return "Person [age=" + age + ", name=" + name + "]";
            34:     }
            35:  
            36: }

          新建一個實現Comparator的實現類PersonComparator:

             1: import java.util.Comparator;
             2:  
             3: public class PersonComparator implements Comparator<Person> {
             4:  
             5:     @Override
             6:     public int compare(Person p1, Person p2) {
             7:         if (p1.getAge() > p2.getAge()) {
             8:             return 1;
             9:         } else if (p1.getAge() < p2.getAge()) {
            10:             return -1;
            11:         }
            12:         return 0;
            13:     }
            14:     
            15: }

          然后再用回我們的CompareTest做測試:

             1: import java.util.Arrays;
             2:  
             3: public class CompareTest {
             4:  
             5:     public static void main(String[] args) {
             6:         Person[] persons = {
             7:                 new Person("P1", 60),
             8:                 new Person("P2", 20),
             9:                 new Person("P3", 40)
            10:         };
            11:         
            12:         System.out.println(Arrays.toString(persons));
            13:         
            14:         Arrays.sort(persons, new PersonComparator());
            15:         
            16:         System.out.println(Arrays.toString(persons));
            17:     }
            18:  
            19: }

          注意:在上面的sort方法中,我們傳進了一個PersonComparator的實例對象作為參數,讀者也可以試試不傳入這個參數,看是否能正確工作。

          結果當然是跟上面演示的例子一樣啦,我就不再重復了。

          posted on 2011-04-12 12:26 Eric_jiang 閱讀(3590) 評論(0)  編輯  收藏 所屬分類: Java
          主站蜘蛛池模板: 金沙县| 恩平市| 镇赉县| 丰原市| 中江县| 鄄城县| 积石山| 青浦区| 台山市| 独山县| 太仆寺旗| 高青县| 武定县| 盘山县| 安平县| 门源| 石阡县| 香港 | 云林县| 宁河县| 沁水县| 静乐县| 海阳市| 抚顺市| 德州市| 灌南县| 游戏| 永州市| 孟州市| 石景山区| 正安县| 绥中县| 西昌市| 浮山县| 色达县| 九龙城区| 阜阳市| 安乡县| 巧家县| 栾城县| 东港市|