博客
关于我
为什么阿里规约手册要求谨慎使用Arrays.asList方法
阅读量:161 次
发布时间:2019-02-28

本文共 1579 字,大约阅读时间需要 5 分钟。

开发过程中,经常会遇到将数组转换为List的需求,而Java中的Arrays.asList()方法看似简单,却隐藏着容易引发的异常问题。作为一名开发人员,了解这一点至关重要,以避免在项目中造成意外崩溃。

Arrays.asList()的潜在问题

以下是一个常见的示例:

@Testpublic void test() {    List
list = Arrays.asList("a", "a", "2"); System.out.println(list.size()); // 输出3 list.add("blog.happyjava.cn"); System.out.println(list.size()); // 此行会抛出UnsupportedOperationException}

运行该代码时,第二行list.add("blog.happyjava.cn");会抛出UnsupportedOperationException异常。这一问题的根源在于Arrays.asList()返回的集合类型与我们熟悉的ArrayList有根本区别。

Arrays.asList()返回的集合类型

通过查看源码可以发现,Arrays.asList()实际返回的是Arrays的一个内部类。尽管这个内部类实现了List接口,但其对集合操作的支持大不相同。具体来说:

  • 该内部类的add方法被禁用,无法通过集合操作进行添加、删除或清空操作。

这意味着任何对集合进行修改操作的尝试都会直接引发异常,严重影响开发效率。

为什么Arrays.asList()不能随意修改集合

通过分析Arrays.asList()的实现,我们可以发现其设计初衷并非为动态集合操作提供支持。它的主要目的是快速地将数组转换为一个视图(view),以便于方便操作,而不是提供一个可修改的集合。

从源码可看出,Arrays.asList()返回的集合类直接继承自AbstractList,并在其基础上禁用了关键的集合操作方法。具体来说:

public boolean add(E e) {    add(size(), e);    return true;}public void add(int index, E element) {    throw new UnsupportedOperationException();}

这意味着任何试图通过集合操作进行添加、删除或替换操作的行为都会直接被禁止。

如何避免Arrays.asList()的潜在问题

在实际开发中,为了避免因使用Arrays.asList()而引发的异常,我们可以采取以下措施:

  • 手动创建ArrayList实例:如果需要对集合进行修改操作,可以直接使用new ArrayList(Arrays.asList(...))的方式,将Arrays视图转换为真实的ArrayList实例。

  • 使用集合工具类:可以考虑使用CollectionUtils等工具类,它们能够将数组转换为可修改的集合,例如:

    List
    list = new ArrayList<>(Arrays.asList("a", "a", "2"));
  • 谨慎使用Arrays.asList():只在不需要修改集合的情况下使用Arrays.asList()。例如,用于只读或显示操作时,可以避免不必要的异常。

  • 总结

    Arrays.asList()是一个强大的工具,但其局限性在于返回的集合无法进行修改操作。作为开发人员,了解这一点并根据实际需求选择合适的集合操作方式,是保障开发质量的关键。

    通过上述方法,我们可以避免因使用Arrays.asList()而引发的异常问题,同时确保代码的健壮性。

    转载地址:http://aquj.baihongyu.com/

    你可能感兴趣的文章
    npm安装教程
    查看>>
    npm报错Cannot find module ‘webpack‘ Require stack
    查看>>
    npm报错Failed at the node-sass@4.14.1 postinstall script
    查看>>
    npm报错fatal: Could not read from remote repository
    查看>>
    npm报错File to import not found or unreadable: @/assets/styles/global.scss.
    查看>>
    npm报错TypeError: this.getOptions is not a function
    查看>>
    npm报错unable to access ‘https://github.com/sohee-lee7/Squire.git/‘
    查看>>
    npm淘宝镜像过期npm ERR! request to https://registry.npm.taobao.org/vuex failed, reason: certificate has ex
    查看>>
    npm版本过高问题
    查看>>
    npm的“--force“和“--legacy-peer-deps“参数
    查看>>
    npm的安装和更新---npm工作笔记002
    查看>>
    npm的常用操作---npm工作笔记003
    查看>>
    npm的常用配置项---npm工作笔记004
    查看>>
    npm的问题:config global `--global`, `--local` are deprecated. Use `--location=global` instead 的解决办法
    查看>>
    npm编译报错You may need an additional loader to handle the result of these loaders
    查看>>
    npm设置淘宝镜像、升级等
    查看>>
    npm设置源地址,npm官方地址
    查看>>
    npm设置镜像如淘宝:http://npm.taobao.org/
    查看>>
    npm配置安装最新淘宝镜像,旧镜像会errror
    查看>>
    NPM酷库052:sax,按流解析XML
    查看>>