Arrays.asList() 返回的list不能add,remove

这篇具有很好参考价值的文章主要介绍了Arrays.asList() 返回的list不能add,remove。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

一.Arrays.asList() 返回的list不能add,remove

Arrays.asList()返回的是List,而且是一个定长的List,所以不能转换为ArrayList,只能转换为AbstractList

原因在于asList()方法返回的是某个数组的列表形式,返回的列表只是数组的另一个视图,而数组本身并没有消失,对列表的任何操作最终都反映在数组上. 所以不支持remove,add方法的

下面是一段很简单的测试代码:  

public class MainFacade {  
    public static void main(String[] args) {  
        List<Integer> list = Arrays.asList(1,2,3);  
        list.add(5);  
        System.out.print(list.toString());  
    }  
}  

不过上面的代码会throw出一个UnsupportedOperationException这样的异常  

Exception in thread "main" java.lang.UnsupportedOperationException at java.util.AbstractList.add(AbstractList.java:148) at java.util.AbstractList.add(AbstractList.java:108) at org.popkit.MainFacade.main(MainFacade.java:14) at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) at java.lang.reflect.Method.invoke(Method.java:606) at com.intellij.rt.execution.application.AppMain.main(AppMain.java:134)  


终其原因是Arrays.asList方法返回的ArrayList是继承自AbstractList同时实现
了RandomAccess和Serializable接口,定义如下:  

private static class ArrayList<E> extends AbstractList<E>  implements RandomAccess, java.io.Serializable  

我们再来看看AbstractList这个类的定义:  

public abstract class AbstractList<E> extends AbstractCollection<E> implements List<E>   

这时我们发现AbstractList这个类的set add remove方法定义如下:

public void add(int index, E element) {  
    throw new UnsupportedOperationException();  
}  
  
public E set(int index, E element) {  
    throw new UnsupportedOperationException();  
}  
  
public E remove(int index) {  
    throw new UnsupportedOperationException();  
}  

现在知道了它throw UnsupportedOperationException异常的原因了。  

通过上面的分析,我们知道,其实通过asList方法得到的List是只读的,那么平时我们怎样避免这样的错误发生?我们可以采用如下方法: 

List<Integer> list = new ArrayList<>(Arrays.asList(1,2,3));  

二、Arrays.asList()陷阱

代码如下: 

Java代码  

public static void main(String[] args) {  
        int[] data = {1,2,3,4,5};  
        List list = Arrays.asList(data);  
        System.out.println("列表中的元素数量是:" + list.size());  
    }  


  注意这里输出的数量是1,原因是,在Arrays.asList中,其接收的参数原型其实是泛型变长参数来的,而基本类型是不能作为范型的参数,按道理应该使用包装类型,但这里缺没有报错, 
因为数组是可以泛型化的,所以转换后在list中就有一个类型为int的数组 

Java代码  

        int[] data = {1,2,3,4,5};  
        List list = Arrays.asList(data);  
        System.out.println("元素类型:" + list.get(0).getClass());  
        System.out.println("前后是否相等:"+data.equals(list.get(0)));  


  可以看到,输出的为元素类型:class [I  
因为jvm不可能输出array类型,array类型属于java.lang.reflect包,通过反射访问 
数组的这个类,编译时候生成的。所以要改为: 

Java代码  

Integer[] data = {1,2,3,4,5};  
List list = Arrays.asList(data);  
System.out.println("列表中的元素数量是:" + list.size());  


 此外,假如如下代码: 

Java代码  

//枚举,声明一个星期  
enum Week{Sun,Mon, Tue, Wed,Thu,Fri,Sat}      
public static void main(String[] args) {  
        //工作日  
        Week[] workDays = {Week.Mon, Week.Tue, Week.Wed,Week.Thu,Week.Fri};  
        //转换为列表  
        List<Week> list = Arrays.asList(workDays);  
        //增加周六也为工作日  
        list.add(Week.Sat);  


 注意这里用add会出错,因为是arrays.aslist中,看代码可以看到这里返回的 
ArrayList不是原来的传统意义上的java.util.arraylist了,而是自己工具类的一个 
静态私有内部类,并没有提供add方法,要自己实现,所以这里是出错了,因此, 
除非确信array.aslist后长度不会增加,否则谨慎使用: 
   List<String> abc=Arrays.asList("a","b","c"),因为这样的长度是无法再add的了 文章来源地址https://www.toymoban.com/news/detail-643302.html

到了这里,关于Arrays.asList() 返回的list不能add,remove的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Arrays.asList():使用指南

    Arrays.asList() 是一个 Java 的静态方法,它可以把一个数组或者多个参数转换成一个 List 集合。这个方法可以作为数组和集合之间的桥梁,方便我们使用集合的一些方法和特性。本文将介绍 Arrays.asList() 的语法、应用场景、坑点和总结。 语法 应用场景 坑点 总结 Arrays.asList() 的语

    2024年02月08日
    浏览(26)
  • Arrays.asList 和 null 类型

    Arrays.asList() 返回的List 是它的内部类,不能使用 retainAll() 取交集,导致元素的删除,会报错。 null 不能使用 instanceof ,返回的都是false。

    2024年02月09日
    浏览(34)
  • Arrays.asList和ArrayList.subList,集合添加/修改遇到的问题

    总结: 使用工具类 Arrays.asList()把数组转换成集合时,不能使用其修改集合相关的方法,它的 add/remove/clear 方法会抛出 UnsupportedOperationException 异常。 注意: 修改原集合元素的值,会影响子集合 修改原集合的结构,会引起ConcurrentModificationException异常 修改子集合元素的值,会

    2024年01月22日
    浏览(59)
  • Java 定义返回一个不能被修改、删除元素的List

      为啥突然分享下这个,也是从mybatis源码看到了,所以想分享下: org.apache.ibatis.plugin.InterceptorChain   使用 Collections.unmodifiableList(); 示例: 运行效果: 不给动。  

    2024年02月13日
    浏览(38)
  • 数组(Arrays)和列表(Lists) — Unity C#

    数组是 C# 提供的最基本的集合。将它们视为一组值的容器,在编程术语中称为元素,每个值都可以单独访问或修改。 · 数组可以存储任何类型的值;所有元素必须属于同一类型。 · 数组的长度或元素数量是在创建时设置的。 · 如果创建时没有指定初始值,则每个元素都会被

    2024年01月23日
    浏览(45)
  • Java中List,Set,数组Arrays相互转化

    很多场合需要进行转换( 例如力扣中 ) 数组转换其他时比较容易,反过来就需要操作一番 以下转换的方法并不唯一,但确保简洁易懂 常规的方法:从数组中拿出元素放进list 用工具类或者库函数: 这个比较容易,从数组中拿出元素放进set(同时会自动去重) 这个需要操作

    2024年02月11日
    浏览(32)
  • LeetCode83. Remove Duplicates from Sorted List

    Given the head of a sorted linked list, delete all duplicates such that each element appears only once. Return the linked list sorted as well. Example 1: Input: head = [1,1,2] Output: [1,2] Example 2: Input: head = [1,1,2,3,3] Output: [1,2,3] Constraints: The number of nodes in the list is in the range [0, 300]. -100 = Node.val = 100 The list is guaranteed t

    2024年01月18日
    浏览(34)
  • Leetcode 82. Remove Duplicates from Sorted List II

    Remove Duplicates from Sorted List II Medium Given the head of a sorted linked list, delete all nodes that have duplicate numbers, leaving only distinct numbers from the original list. Return the linked list sorted as well. Example 1: Input: head = [1,2,3,3,4,4,5] Output: [1,2,5] Example 2: Input: head = [1,1,1,2,3] Output: [2,3] Constraints: The number of n

    2024年02月10日
    浏览(29)
  • LeetCode //C - 82. Remove Duplicates from Sorted List II

    Given the head of a sorted linked list, delete all nodes that have duplicate numbers, leaving only distinct numbers from the original list . Return the linked list sorted as well.   Example 1: Input: head = [1,2,3,3,4,4,5] Output: [1,2,5] Example 2: Input: head = [1,1,1,2,3] Output: [2,3] Constraints: The number of nodes in the list is in the range [0, 300]

    2024年02月10日
    浏览(32)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包