Java中Arrays的asList()方法

2017-03-28 09:27:41

Java中Arrays的asList()方法 可以将 数组转为List 但是,这个数组类型必须是 引用类型的,如果是8中基本数据类型就不可以 原因如下,引用别人的一篇文章:



最近在用Arrays的asList()生成的List时,List元素的个数时而不正确。


Java代码

//经多次测试,只要传递的基本类型的数组,生成List的元素个数均为1  
char arrc = {'a','b'};  
int  arrint = {1,2,4};  
Arrays.asList(arrc).size() ;//  结果为1;  
Arrays.asList(arrint ).size() ;//结果为1;  
   
//传递对象数组,元素个数正确。  
String arrstr = {"a","b","java","spring","hadoop","lucene"};  
Arrays.asList(arrstr ).size() ;//结果为6;  
跟源码:


Java代码  


  public static <T> List<T> asList(T... a) {  
 return new ArrayList<T>(a);  
}  
继续跟,Arrays的私有内部类ArrayList  (没搞明白,为什么这里也起名为ArrayList)


private final E[] a;  
  
ArrayList(E[] array) {  
           if (array==null)  
               throw new NullPointerException();  
    a = array;  
}  
  
public int size() {  
    return a.length;  
}  
发现问题出在java5 的可变参数上。于是写了demo,测试。


public class TestArray {  
    PrintStream out = System.out;  
    @Test  
    public void array() {  
        char[] arrc = {'a','b','c','d','e'};  
        out.println("传递char数组:");  
        print(arrc);  
        out.println("直接传递:");  
        print('a','b','c','d','e');  
        out.println("----------------------------");  
          
        int[] arri = {1,2,3,4,5,6,7};  
        out.println("传递int数组:");  
        print(arri);  
        out.println("直接传递:");  
        print(1,2,3,4,5,6,7);  
        out.println("----------------------------");  
          
        Integer[] arrInt = {1,2,3,4,5,6,7};  
        out.println("传递Integer数组:");  
        print(arrInt);  
        out.println("直接传递:");  
        print(1,2,3,4,5,6,7);  
        out.println("----------------------------");  
          
        String[] arrs = {"a","b","c","d","e"};  
        out.println("传递String数组:");  
        print(arrs);  
        out.println("直接传递:");  
        print('a','b','c','d','e');  
        out.println("----------------------------");  
    }  
      
    public void print(Object...arr){  
        out.print("内容:"+Arrays.toString(arr));  
        out.println("\t\t数组长度:"+arr.length+" ");  
    }  
}  
输出结果为:


传递char数组:  
内容:[[C@defa1a]      数组长度:1   
直接传递:  
内容:[a, b, c, d, e]      数组长度:5   
----------------------------  
传递int数组:  
内容:[[I@f5da06]      数组长度:1   
直接传递:  
内容:[1, 2, 3, 4, 5, 6, 7]        数组长度:7   
----------------------------  
传递Integer数组:  
内容:[1, 2, 3, 4, 5, 6, 7]        数组长度:7   
直接传递:  
内容:[1, 2, 3, 4, 5, 6, 7]        数组长度:7   
----------------------------  
传递String数组:  
内容:[a, b, c, d, e]      数组长度:5   
直接传递:  
内容:[a, b, c, d, e]      数组长度:5   
----------------------------  
java 5 可变参数,直接传递值与传递数组处理的机制不太相同。


如果直接传递数组,基本类型数组将被视为一个对象而不会被解析成数组,如果直接传递参数将能正常解析。因此传递基本类型数组时强烈建议转为其封装类对象的数组  int ->Integer ,long->Long …………。(未对其封装)




这样写就很清楚了吧
public static void main(String[] args) {
  int[] intArray = {1,2,3};
  List<int[]> myList = Arrays.asList(intArray);
  System.out.println(myList.size());
  System.out.println(myList.get(0).length);


}


大概明白了:定义:


public static <T> List<T> asList(T... a) { 
return new ArrayList<T>(a); 
}


这个T必须是对象类型。好比我们不能new ArrayList<int> 只能new ArrayList<Integer>


  • 2019-12-04 10:46:26

    nuxt.js项目中全局捕获异常并生成错误日志全过程

     需求:客户在使用过程中页面报错时,可以生成错误记录传回服务器,以便改进。   步骤:     一.全局捕获异常,     二.发送到服务端,     三.生成错误日志。   一.全局捕获异常 如图,vue提供了errorHandle这个方法来处理全局异常,更多详细内容参见官网。

  • 2019-12-04 10:47:59

    nuxt.js项目中全局捕获异常并生成错误日志全过程

     需求:客户在使用过程中页面报错时,可以生成错误记录传回服务器,以便改进。   步骤:     一.全局捕获异常,     二.发送到服务端,     三.生成错误日志。   一.全局捕获异常 如图,vue提供了errorHandle这个方法来处理全局异常,更多详细内容参见官网。

  • 2019-12-04 10:48:18

    vue 项目资源文件 static 和 assets 不说区别直接使用?

    assets中资源会webpack构建压缩到你代码中,而static文件直接引用。 static 中长存放类包、插件等第三方的文件,assets里放属资源文件比如自己资源图片、css文件、js文件。 引入资源的方式static文件夹可以使用~/static/方式引入, assets文件夹可以使用 ~@/assets 方式引入

  • 2019-12-05 17:01:36

    Vue 结合 Axios 接口超时统一处理

    当网路慢的时候。又或者公司服务器不在内地的时候,接口数据请求不回来超时报错的情况相信大家肯定遇到过的,这里我把我公司项目请求超时的处理方法分享下,希望看过后有帮助。

  • 2019-12-05 17:13:40

    JS模板工具lodash.template的简单用法

    lodash是从underscore分支的一个项目,之前我写了一篇JS模板工具underscore.template的简单用法,lodash跟underscore很相似,这也简单介绍一下lodash的template方法。 先把underscore的文章中用过的代码贴过来,把underscore的js文件换成lodash的js,其他一字不改,然后我们试试:

  • 2019-12-06 10:47:29

    date-fns日期工具的使用方法详解

    isToday() 判断传入日期是否为今天 isYesterday() 判断传入日期是否为昨天 isTomorrow() 判断传入日期是否为 format() 日期格式化 addDays() 获得当前日期之后的日期 addHours() 获得当前时间n小时之后的时间点 addMinutes() 获得当前时间n分钟之后的时间 addMonths() 获得当前月之后n个月的月份 subDays() 获得当前时间之前n天的时间 subHours() 获得当前时间之前n小时的时间 subMinutes() 获得当前时间之前n分钟的时间 subMonths() 获得当前时间之前n个月的时间 differenceInYears() 获得两个时间相差的年份 differenceInWeeks() 获得两个时间相差的周数 differenceInDays() 获得两个时间相差的天数 differenceInHours() 获得两个时间相差的小时数 differenceInMinutes() 获得两个时间相差的分钟数

  • 2019-12-06 10:49:39

    npm 查看源 换源

    npm,cnpm,查看源,切换源,npm config set registry https://registry.npmjs.org

  • 2019-12-06 11:01:31

    npm发布包流程详解 有demo

    npm发布包步骤,以及踩过的坑(见红颜色标准): 1.注册npm账号,并完成Email认证(否则最后一步提交会报Email错误) 2.npm添加用户或登陆:npm adduser 或 npm login