• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            為生存而奔跑

               :: 首頁 :: 聯(lián)系 :: 聚合  :: 管理
              271 Posts :: 0 Stories :: 58 Comments :: 0 Trackbacks

            留言簿(5)

            我參與的團隊

            搜索

            •  

            積分與排名

            • 積分 - 330224
            • 排名 - 74

            最新評論

            閱讀排行榜

            評論排行榜

            1、假設定義了一個對象TypeName,TypeName[] t=new TypeName[30],這條語句只是申請了30個指向TypeName類型的引用,并沒有申請30個TypeName類型的對象。如果要使用,必須依次重新申請
            for(int i=0;i<30;i++)
              t[i]=new TypeName();
            2、對對象數(shù)組進行排序等操作,需要在該對象上實現(xiàn)comparable接口。然后直接調用Arrays.sort(對象數(shù)組名)。如果要指定排序區(qū)間,可以Arrays.sort(對象數(shù)組名,i,j).這表示從該數(shù)組的下標為i處開始到下標為j-1處排序。
            3、Comparable   &   Comparator   都是用來實現(xiàn)集合中的排序的,只是Comparable是在集合內部定義的方法實現(xiàn)的排序,Comparator是在集合外部實現(xiàn)的排序,所以,如想實現(xiàn)排序,就需要在集合外定義Comparator接口的方法   或   在集合內實現(xiàn)Comparable接口的方法。 
              具體請看   <Thinking   in   java>

            Comparable是一個對象本身就已經(jīng)支持自比較所需要實現(xiàn)的接口(如String   Integer自己就可以完成比較大小操作)  
               
              而Comparator是一個專用的比較器,當這個對象不支持自比較或者自比較函數(shù)不能滿足你的要求時,你可以寫一個比較器來完成兩個對象之間大小的比較。       
                
              可以說一個是自已完成比較,一個是外部程序實現(xiàn)比較的差別而已。

            用Comparator是策略模式(strategy   design   pattern),就是不改變對象自身,而用一個策略對象(strategy   object)來改變它的行為。  
               
              比如:你想對整數(shù)采用絕對值大小來排序,Integer是不符合要求的,你不需要去修改Integer類(實際上你也不能這么做)去改變它的排序行為,只要使用一個實現(xiàn)了Comparator接口的對象來實現(xiàn)控制它的排序就行了。  

               1.  //AbsComparator.java      
               2.   import   java.util.*;      
               
            3.   public   class   AbsComparator   implements   Comparator   {      
               
            4.       public   int   compare(Object   o1,   Object   o2)   {      
               
            5.           int   v1   =   Math.abs(((Integer)o1).intValue());      
               
            6.           int   v2   =   Math.abs(((Integer)o2).intValue());      
               
            7.           return   v1   >   v2   ?   1   :   (v1   ==   v2   ?   0   :   -1);      
               
            8.       }      
               
            9.   }      
              
            10.        
              
            11.   可以用下面這個類測試AbsComparator:      
              
            12.        
              
            13.   //Test.java      
              14.   import   java.util.*;      
              
            15.        
              
            16.   public   class   Test   {      
              
            17.       public   static   void   main(String[]   args)   {      
              
            18.        
              
            19.           //產生一個20個隨機整數(shù)的數(shù)組(有正有負)      
              20.           Random   rnd   =   new   Random();      
              
            21.           Integer[]   integers   =   new   Integer[20];      
              
            22.           for(int   i   =   0;   i   <   integers.length;   i++)      
              
            23.           integers[i]   =   new   Integer(rnd.nextInt(100)   *   (rnd.nextBoolean()   ?   1   :   -1));      
              
            24.        
              
            25.           System.out.println("用Integer內置方法排序:");      
              
            26.           Arrays.sort(integers);      
              
            27.           System.out.println(Arrays.asList(integers));      
              
            28.        
              
            29.           System.out.println("用AbsComparator排序:");      
              
            30.           Arrays.sort(integers,   new   AbsComparator());      
              
            31.           System.out.println(Arrays.asList(integers));      
              
            32.       }      
              
            33.   }     



            posted on 2009-10-22 16:18 baby-fly 閱讀(487) 評論(0)  編輯 收藏 引用 所屬分類: Java
            欧美性大战久久久久久| 久久婷婷人人澡人人| 激情伊人五月天久久综合| 色综合久久久久久久久五月| 国产精品久久久久影院嫩草| 久久99热这里只有精品国产| 人妻无码αv中文字幕久久| 26uuu久久五月天| 久久精品国产亚洲av日韩| 亚洲美日韩Av中文字幕无码久久久妻妇 | 蜜桃麻豆www久久| 国产成人久久精品一区二区三区| 婷婷久久综合九色综合98| 中文字幕无码久久久| 99久久精品九九亚洲精品| 激情伊人五月天久久综合| 欧美亚洲国产精品久久| 精品久久久久久国产牛牛app| 91精品国产综合久久精品| 久久久久久午夜精品| 日日狠狠久久偷偷色综合0| 久久香蕉一级毛片| 久久精品www人人爽人人| 亚洲va国产va天堂va久久| 久久人人爽人人爽人人av东京热 | 开心久久婷婷综合中文字幕| a级毛片无码兔费真人久久| 国产精品久久免费| 久久国产精品成人免费| 大伊人青草狠狠久久| 久久精品成人免费网站| 精品久久777| 国产ww久久久久久久久久| 99久久国产免费福利| 99久久精品国产毛片| 久久久WWW免费人成精品| 久久久受www免费人成| 久久这里只精品99re66| 一本久久知道综合久久| 99久久99久久久精品齐齐| 亚洲国产精品久久久久|