zoukankan      html  css  js  c++  java
  • ArrayList和数组间的相互转换

    开发中不免碰到List与数组类型之间的相互转换,举一个简单的例子: 

    Java代码  收藏代码
    1. package test.test1;  
    2. import java.util.ArrayList;  
    3. import java.util.List;  
    4. public class Test {  
    5.   
    6.     /** 
    7.      * @param args 
    8.      */  
    9.     public static void main(String[] args) {  
    10.         List list=new ArrayList();  
    11.         list.add("王利虎");  
    12.         list.add("张三");  
    13.         list.add("李四");  
    14.         int size=list.size();  
    15.         String[] array=new String[size];  
    16.         for(int i=0;i<list.size();i++){  
    17.             array[i]=(String)list.get(i);  
    18.         }  
    19.         for(int i=0;i<array.length;i++){  
    20.             System.out.println(array[i]);  
    21.         }  
    22.     }  
    23. }  



    正如上面所列举的,当要将ArrayList类型的数据转换为String[]的时候,必须对List类型进行遍历,其实没有这种必要,List提供给我们一个很好的方法解决List转换成为数组的问题,不防再看一个例子: 
    package test.test1; 

    import java.util.ArrayList; 
    import java.util.List; 

    Java代码  收藏代码
    1. public class Test {  
    2.     public static void main(String[] args) {  
    3.         List<String> list=new ArrayList<String>();  
    4.         list.add("王利虎");  
    5.         list.add("张三");  
    6.         list.add("李四");  
    7.         int size=list.size();  
    8.         String[] array = (String[])list.toArray(new String[size]);  
    9.         for(int i=0;i<array.length;i++){  
    10.             System.out.println(array[i]);  
    11.         }  
    12.     }  
    13. }  


    你是否发现这才是你想要的呢?其实很简单,ArrayList提供public <T> T[] toArray(T[] a)方法返回一个按照正确的顺序包含此列表中所有元素的数组;返回数组的运行时类型就是指定数组的运行时类型。如果列表能放入指定的数组,则返回放入此列表元素的数组。否则,将根据指定数组的运行时类型和此列表的大小分配一个新的数组。 
    如果指定的数组能容纳列表并有剩余空间(即数组的元素比列表的多),那么会将数组中紧跟在集合末尾的元素设置为 null。这对确定列表的长度很有用,但只 在调用方知道列表中不包含任何 null 元素时才有用。 
        那么又怎么将数组转换成为List呢?不防再看一个小小的例子,如下所示: 

    Java代码  收藏代码
    1. package test.test1;  
    2. import java.util.ArrayList;  
    3. import java.util.List;  
    4. public class Test {  
    5.     public static void main(String[] args) {  
    6.         String[] array=new String[3];  
    7.         array[0]="王利虎";  
    8.         array[1]="张三";  
    9.         array[2]="李四";  
    10.         List<String> list=new ArrayList<String>();  
    11.         for(int i=0;i<array.length;i++){  
    12.             list.add(array[i]);  
    13.         }  
    14.         for(int i=0;i<list.size();i++){  
    15.             System.out.println(list.get(i));  
    16.         }  
    17.     }  
    18. }  


    你是不发现很费事啊?其实数组转换成为List的问题Arrays对象也提供给我们public static <T> List<T> asList(T... a)供我们调用, 试运行下面的例子: 

    Java代码  收藏代码
    1. package test.test1;  
    2.   
    3. import java.util.Arrays;  
    4. import java.util.List;  
    5.   
    6. public class Test {  
    7.     public static void main(String[] args) {  
    8.         String[] array=new String[3];  
    9.         array[0]="王利虎";  
    10.         array[1]="张三";  
    11.         array[2]="李四";  
    12.         List<String> list=Arrays.asList(array);  
    13.         for(int i=0;i<list.size();i++){  
    14.             System.out.println(list.get(i));  
    15.         }  
    16.           
    17.   
    18.     }  
    19. }  


        简单吧,asList方法返回一个受指定数组支持的固定大小的列表,此方法同 Collection.toArray 一起,充当了基于数组的 API 与基于 collection 的 API 之间的桥梁。返回的列表是可序列化的,并且实现了 RandomAccess。除此之外, 此方法还提供了一个创建固定长度的列表的便捷方法,该列表被初始化为包含多个元素: 

    Java代码  收藏代码
    1.   package test.test1;  
    2. import java.util.Arrays;  
    3. import java.util.List;  
    4. public class Test1 {  
    5.     public static void main(String[] args) {  
    6.         List<String> list = Arrays.asList("王利虎","张三","李四");  
    7.         for(int i=0;i<list.size();i++){  
    8.             System.out.println(list.get(i));  
    9.         }  
    10.     }  
    11. }  


    下次遇到这样的问题,你一定会想到它,不会再for你的List对象或数组对象了吧! 

  • 相关阅读:
    poj 3122 (二分查找)
    poj 1064 (二分+控制精度) && hdu 1551
    hdu 2199 (二分)
    hdu 2141 (二分)
    poj 2954 Triangle(Pick定理)
    poj 1265 Area (Pick定理+求面积)
    hdu 4946 Just a Joke(数学+物理)
    zoj 1199 几何公式推导
    MMORGP大型游戏设计与开发(客户端架构 part13 of vegine)
    MMORPG大型游戏设计与开发(客户端架构 part12 of vegine)
  • 原文地址:https://www.cnblogs.com/henuyuxiang/p/3860451.html
Copyright © 2011-2022 走看看