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

    ArrayList和数组间的相互转换

    http://wanglihu.iteye.com/blog/243238

       开发中不免碰到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对象或数组对象了吧!
  • 相关阅读:
    海尔U+的启发:让用户对智能家居拥有“话语权”
    关于hash和ico的一些关联
    二维码简单介绍
    卡特兰数 大数模板
    C++ Linux 多线程之创建、管理线程
    Objective-c开发教程--MRC和ARC混编
    APP 打包測试流程 从零開始
    hdu4848 求到达每一个点总时间最短(sum[d[i]])。
    表结构变更后出现的ERROR OGG-01161 Bad column index (88)
    【Linux学习】Ubuntu下内核编译(一)
  • 原文地址:https://www.cnblogs.com/kungfupanda/p/7747004.html
Copyright © 2011-2022 走看看