<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    隨筆-144  評論-80  文章-1  trackbacks-0
    操縱java數(shù)組
    如果你做過很多java程序,你可能對java集合類很熟悉,例如Vector和ArrayList。你可以創(chuàng)建一個集合并向其中增加元素:

       List lst = new ArrayList();

       lst.add(new Integer(37));

    在這個特殊的范例中,一個整型值37用于構(gòu)造一個Integer封裝類對象,然后那個對象被加入到列表。

    這個簡單的范例展示集合的一個基礎(chǔ)-他們用于操縱一列對象,其中的每個對象是一個類或者接口類型。因此,一個ArrayList可以包含Object,String,Float以及Runnable類型的對象。集合類不能用于原始數(shù)據(jù)類型的列表,例如整型數(shù)組。

    如果你在你的程序中使用原始類型的數(shù)組,你如何操縱它們呢?這個技巧就給你展示幾個你可以使用的技術(shù)。

    第一個技術(shù)是排序。java.util.Arrays類包含一套排序和查找數(shù)組的類方法,例如:

       import java.util.Arrays;

       public class ArrayDemo1 {
           public static void main(String args[]) {
               int vec[] = {37, 47, 23, -5, 19, 56};
               Arrays.sort(vec);
               for (int i = 0; i < vec.length; i++) {
                   System.out.println(vec[i]);
               }
           }
       }

    這個演示程序初始化一個整數(shù)數(shù)組然后調(diào)用Arrays.sort升序排序那個數(shù)組。

    類似的,你可以在排完序的數(shù)組上進行二分法查找:

       import java.util.Arrays;

       public class ArrayDemo2 {
           public static void main(String args[]) {
               int vec[] = {-5, 19, 23, 37, 47, 56};
               int slot = Arrays.binarySearch(vec, 35);
               slot = -(slot + 1);
               System.out.println("insertion point = " + slot);
           }
       }

    這個程序有個微妙的概念,如果二分法查找失敗它將返回:

    -(insertion point) - 1

    這個演示程序以參數(shù)35調(diào)用查找方法,而那個參數(shù)在數(shù)組中不存在,方法返回值-4,如果這個值加一再取其負(fù)數(shù)就得到3,這就是35應(yīng)該被插入到數(shù)組中的位置,換言之,值-5, 19和23在數(shù)組中占據(jù)的位置是0,1和2。因此值35應(yīng)該在索引3的位置,而37, 47以及56順延。搜索方法并不進行實際的插入操作而只是指出應(yīng)該在何處插入。

    除了排序和查找,我們還可以對原始類型數(shù)組做什么?另一個有用的技術(shù)是將一個原始數(shù)組轉(zhuǎn)換為等價的對象類型數(shù)組。每個對應(yīng)元素使用它們的封裝器類,例如在封裝數(shù)組中,37成為Integer(37)。

       import java.util.Arrays;
       import java.lang.reflect.Array;
       
       public class ArrayDemo3 {
       
           // if input is a single-dimension primitive array,

           // return a new array consisting of wrapped elements,
           // else just return input argument
       
           public static Object toArray(Object vec) {
       
               // if null, return

       
               if (vec == null) {
                   return vec;
               }
       
               // if not an array or elements not primitive, return

       
               Class cls = vec.getClass();
               if (!cls.isArray()) {
                   return vec;
               }
               if (!cls.getComponentType().isPrimitive()) {
                   return vec;
               }
       
               // get array length and create Object output array

       
               int length = Array.getLength(vec);
               Object newvec[] = new Object[length];
       
               // wrap and copy elements

       
               for (int i = 0; i < length; i++) {
                   newvec[i] = Array.get(vec, i);
               }
       
               return newvec;
           }
       
           public static void main(String args[]) {
       
               // create a primitive array

       
               int vec[] = new int[]{1, 2, 3};
       
               // wrap it

       
               Object wrappedvec[] = (Object[])toArray(vec);
       
               // display result

       
               for (int i = 0; i < wrappedvec.length; i++) {
                   System.out.println(wrappedvec[i]);
               }
           }
       }

    方法"toArray"的參數(shù)是一個Object對象(數(shù)組可以被賦值給一個Object引用)。如果參數(shù)是null或者代表的不是原始類型數(shù)組那么這個方法簡單的返回參數(shù)值。java.lang.Class工具類用于判斷參數(shù)是否是一個數(shù)組并獲取數(shù)組的底層元素的類型。

    一旦做完這些檢查,使用java.lang.reflect.Array工具類的反射工具方法就可以獲取原始數(shù)組的長度并獲得數(shù)組的單個元素。Array.get獲得的每個元素被返回到封裝器類中,例如Integer或者Double。

    最終的范例基于前面的那個并向你展示如何在數(shù)組上使用集合特性。這假設(shè)你已經(jīng)有一個對象數(shù)組。

       import java.util.Arrays;
       import java.util.List;

       public class ArrayDemo4 {
           public static void main(String args[]) {
               Object vec[] = {new Integer(37), new Integer(47)};
               List lst = Arrays.asList(vec);
               lst.set(1, new Integer(57));
               for (int i = 0; i < vec.length; i++) {
                   System.out.println(vec[i]);
               }
           }
       }


    在這個程序中,vec是一個對象數(shù)組,包含Integer(37)和Integer(47),然后Arrays.asList被調(diào)用。它返回一個集合(List接口類型),使用數(shù)組作為集合的后臺存儲。換言之,ArrayList這樣的集合類型在它內(nèi)部有某種存儲類型去存儲集合元素。在這個例子中,使用的存儲類型是作為參數(shù)傳遞到Arrays.asList的數(shù)組。這意味著集合方法所做的改變會被反射到底層的數(shù)組。

    修改集合中的元素1導(dǎo)致底層的數(shù)組也改變,程序的輸出是:

    37
    57

    因此如果你有一個對象數(shù)組,你可以在它上面使用集合特性,數(shù)組自身作為底層存儲。

    我們也可以將集合轉(zhuǎn)換為一個對象數(shù)組,例如:

    Object vec[] = lst.toArray();

    摘自:http://www.javaresearch.org/article/showarticle.jsp?column=1&thread=2994

    posted on 2005-03-21 17:07 小力力力 閱讀(628) 評論(0)  編輯  收藏 所屬分類: LINUX
    主站蜘蛛池模板: 亚洲中文字幕无码爆乳app| 成人激情免费视频| 日韩免费高清视频| 国产精品免费一区二区三区四区| 蜜芽亚洲av无码一区二区三区| 亚洲一卡2卡三卡4卡有限公司| 亚洲精品久久久www| 永久免费无码网站在线观看| 在线成人爽a毛片免费软件| av成人免费电影| 久久亚洲国产午夜精品理论片| 蜜臀91精品国产免费观看| 综合在线免费视频| 精品一区二区三区无码免费直播| 亚洲性猛交xx乱| 免费99热在线观看| 成人自慰女黄网站免费大全| 亚洲AV电影天堂男人的天堂| 中文字幕亚洲综合久久综合| 亚洲精品国产肉丝袜久久| 亚洲成av人片天堂网| 国产亚洲精品资在线| 久久大香伊焦在人线免费| 两性色午夜视频免费网| 国产精品永久免费视频| 中美日韩在线网免费毛片视频| 亚洲福利视频一区| 成人特黄a级毛片免费视频| 久久久久av无码免费网| 99久久综合精品免费| 国产亚洲精品美女久久久久| 亚洲精品无码日韩国产不卡av| 亚洲制服丝袜第一页| 亚洲AV综合色区无码二区爱AV| 国产成人亚洲综合无码| 亚洲福利精品电影在线观看| 亚洲国产精品一区二区第四页| 亚洲国产精品日韩| 久久国产成人亚洲精品影院| 亚洲国产一成久久精品国产成人综合| 日韩精品亚洲专区在线观看|