<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ù)組上進(jìn)行二分法查找:

       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順延。搜索方法并不進(jìn)行實(shí)際的插入操作而只是指出應(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 小力力力 閱讀(619) 評論(0)  編輯  收藏 所屬分類: LINUX
    主站蜘蛛池模板: 亚洲国产精品无码久久青草 | 日韩一区二区三区免费体验| 1000部无遮挡拍拍拍免费视频观看 | 亚洲国产美女在线观看| 亚洲无成人网77777| 久久久精品免费国产四虎| 一区二区三区在线免费看| 成人在线免费看片| 免费a级黄色毛片| 亚洲av无码国产精品夜色午夜| 亚洲国产精品久久久久久| 亚洲中文字幕无码久久2020| av成人免费电影| 在线观看日本免费a∨视频| 亚洲av无码成人精品区| 麻豆91免费视频| 精品国产污污免费网站aⅴ| 亚洲偷自拍拍综合网| 亚洲国产成人资源在线软件| 日韩在线视频播放免费视频完整版 | 久久青草免费91观看| 免费中文字幕在线| h视频免费高清在线观看| 久久精品国产亚洲AV麻豆不卡 | 亚洲а∨天堂久久精品| 国产裸体美女永久免费无遮挡| 欧洲乱码伦视频免费| 午夜亚洲国产理论秋霞| 未满十八私人高清免费影院| 亚洲中文字幕无码爆乳av中文| 成人无码a级毛片免费| 免费人成在线观看网站品爱网日本| 一级一看免费完整版毛片| 国产精品视频免费一区二区三区| 亚洲国产精品综合久久2007| 成年人免费视频观看| 亚洲国产精品久久久久| 免费观看的毛片手机视频| 国产亚洲sss在线播放| 中文字幕免费视频| 亚洲人成在线电影|