• <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)

            我參與的團隊

            搜索

            •  

            積分與排名

            • 積分 - 328615
            • 排名 - 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接口。然后直接調(diào)用Arrays.sort(對象數(shù)組名)。如果要指定排序區(qū)間,可以Arrays.sort(對象數(shù)組名,i,j).這表示從該數(shù)組的下標為i處開始到下標為j-1處排序。
            3、Comparable   &   Comparator   都是用來實現(xiàn)集合中的排序的,只是Comparable是在集合內(nèi)部定義的方法實現(xiàn)的排序,Comparator是在集合外部實現(xiàn)的排序,所以,如想實現(xiàn)排序,就需要在集合外定義Comparator接口的方法   或   在集合內(nèi)實現(xiàn)Comparable接口的方法。 
              具體請看   <Thinking   in   java>

            Comparable是一個對象本身就已經(jīng)支持自比較所需要實現(xiàn)的接口(如String   Integer自己就可以完成比較大小操作)  
               
              而Comparator是一個專用的比較器,當這個對象不支持自比較或者自比較函數(shù)不能滿足你的要求時,你可以寫一個比較器來完成兩個對象之間大小的比較。       
                
              可以說一個是自已完成比較,一個是外部程序?qū)崿F(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.           //產(chǎn)生一個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內(nèi)置方法排序:");      
              
            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 閱讀(484) 評論(0)  編輯 收藏 引用 所屬分類: Java
            色狠狠久久综合网| 99久久久久| 性高朝久久久久久久久久| 国内精品欧美久久精品| 久久福利片| 男女久久久国产一区二区三区 | 久久综合给合久久狠狠狠97色 | 亚洲国产精品一区二区久久hs| 久久综合88熟人妻| 人妻丰满?V无码久久不卡| 欧美va久久久噜噜噜久久| 久久精品国产一区二区三区| 亚洲精品乱码久久久久久按摩| 51久久夜色精品国产| 国产偷久久久精品专区| 久久精品成人一区二区三区| 午夜精品久久久久久毛片| 久久久久国色AV免费观看| 国产成人精品久久一区二区三区| 天堂无码久久综合东京热| 久久精品成人国产午夜| 亚洲国产另类久久久精品小说| 久久强奷乱码老熟女网站| 国产一级持黄大片99久久| 久久久久久久97| 色婷婷久久综合中文久久一本| AAA级久久久精品无码区| 国产精品久久久久久久久鸭| 亚洲午夜久久久久久噜噜噜| 偷偷做久久久久网站| 免费一级欧美大片久久网| 久久久精品视频免费观看| 国产精品成人久久久久久久| 69久久夜色精品国产69| .精品久久久麻豆国产精品| 色妞色综合久久夜夜| 色8久久人人97超碰香蕉987| 久久精品国产精品亚洲毛片| 久久水蜜桃亚洲av无码精品麻豆| 亚洲精品乱码久久久久久按摩| 99久久精品国产一区二区|