原來(lái)Java中有兩個(gè)ArrayList
首先給出一段代碼:
public class AslistMethod { public static void main(String[] args) { String sentence = "i love you"; List<String> words = Arrays.asList(sentence.split(" ")); for (int i = 0; i < words.size(); ) { if (words.get(i).equals("love")) { words.remove(i); continue; } i++; } System.out.println(words); }
然后,運(yùn)行這段代碼,最后,報(bào)錯(cuò)了:
Exception in thread "main" java.lang.UnsupportedOperationException at java.util.AbstractList.remove(AbstractList.java:161) at list.AslistMethod.main(AslistMethod.java:12)
錯(cuò)誤鏈的棧底list.AslistMethod.main(AslistMethod.java:12)說(shuō)的是這一行代碼:
words.remove(i);
這個(gè)錯(cuò)誤讓我很迷茫,因?yàn)槲覍戇@段代碼前大概看了一下,Arrays.asList方法返回的是一個(gè)ArrayList,咋就不能remove了呢?接下來(lái),由于一個(gè)小小的失誤,把Arrays.asList的結(jié)果賦給了java.util.ArrayList,居然賦值不成功,我立馬有種瞎貓碰上死耗子的感覺(jué)。然后,就順著Arrays.asList方法一直點(diǎn)下去,發(fā)現(xiàn)此ArrayList非彼ArrayList。Arrays.asList返回的是java.util.Arrays.ArrayList,它只是Arrays的一個(gè)內(nèi)部類。它的代碼不長(zhǎng),這里直接貼出來(lái):
private static class ArrayList<E> extends AbstractList<E> implements RandomAccess, java.io.Serializable { private static final long serialVersionUID = -2764017481108945198L; private final E[] a; ArrayList(E[] array) { a = Objects.requireNonNull(array); } @Override public int size() { return a.length; } @Override public Object[] toArray() { return a.clone(); } @Override @SuppressWarnings("unchecked") public <T> T[] toArray(T[] a) { int size = size(); if (a.length < size) return Arrays.copyOf(this.a, size, (Class<? extends T[]>) a.getClass()); System.arraycopy(this.a, 0, a, 0, size); if (a.length > size) a[size] = null; return a; } @Override public E get(int index) { return a[index]; } @Override public E set(int index, E element) { E oldValue = a[index]; a[index] = element; return oldValue; } @Override public int indexOf(Object o) { if (o==null) { for (int i=0; i<a.length; i++) if (a[i]==null) return i; } else { for (int i=0; i<a.length; i++) if (o.equals(a[i])) return i; } return -1; } @Override public boolean contains(Object o) { return indexOf(o) != -1; } @Override public Spliterator<E> spliterator() { return Spliterators.spliterator(a, Spliterator.ORDERED); } }
從源碼看到,它繼承自AbstractList,并且沒(méi)有remove方法,我找到AbstractList的remove方法:
public E remove(int index) { throw new UnsupportedOperationException(); }
這就是錯(cuò)誤信息的來(lái)源。最終知道,Arrays.asList返回的ArrayList并不支持remove,實(shí)際上,java.util.Arrays.ArrayList不支持任何形式的元素刪除。
總結(jié)一下,這次問(wèn)題的解決確實(shí)有點(diǎn)兒瞎貓碰到死耗子的味道,但是,只要我認(rèn)真看一下報(bào)的錯(cuò)誤:
at java.util.AbstractList.remove(AbstractList.java:161)
調(diào)用java.util.AbstractList的remove方法和我預(yù)期的不一樣,它就能清晰地告訴我方向。
希望本文所述對(duì)大家學(xué)習(xí)java程序設(shè)計(jì)有所幫助。
- java正則表達(dá)式實(shí)現(xiàn)提取需要的字符并放入數(shù)組【ArrayList數(shù)組去重復(fù)功能】
- Java中ArrayList和LinkedList的遍歷與性能分析
- java Vector和ArrayList的分析及比較
- Java ArrayList 實(shí)現(xiàn)實(shí)例講解
- java ArrayList集合中的某個(gè)對(duì)象屬性進(jìn)行排序的實(shí)現(xiàn)代碼
- 由ArrayList來(lái)深入理解Java中的fail-fast機(jī)制
- 分析Java中ArrayList與LinkedList列表結(jié)構(gòu)的源碼
- Java中ArrayList類的用法與源碼完全解析
- Java ArrayList.toArray(T[]) 方法的參數(shù)類型是 T 而不是 E的原因分析
- java 對(duì)ArrayList進(jìn)行分頁(yè)實(shí)例代碼
相關(guān)文章
自定義對(duì)象作為HashMap的Key問(wèn)題
這篇文章主要介紹了自定義對(duì)象作為HashMap的Key問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-01-01Spring mvc是如何實(shí)現(xiàn)與數(shù)據(jù)庫(kù)的前后端的連接操作的?
今天給大家?guī)?lái)的是關(guān)于Spring mvc的相關(guān)知識(shí),文章圍繞著Spring mvc是如何實(shí)現(xiàn)與數(shù)據(jù)庫(kù)的前后端的連接操作的展開(kāi),文中有非常詳細(xì)的介紹及代碼示例,需要的朋友可以參考下2021-06-06SpringBoot開(kāi)發(fā)實(shí)戰(zhàn)系列之定時(shí)器
定時(shí)任務(wù)我想諸位童鞋都不陌生,簡(jiǎn)而言之名為“設(shè)定定時(shí)鬧鐘做某件事情”,下面這篇文章主要給大家介紹了關(guān)于SpringBoot定時(shí)器的相關(guān)資料,需要的朋友可以參考下2021-08-08JAVA獲取rabbitmq消息總數(shù)過(guò)程詳解
這篇文章主要介紹了JAVA獲取rabbitmq消息總數(shù)過(guò)程詳解,公司使用的是rabbitMQ,需要做監(jiān)控預(yù)警的job去監(jiān)控rabbitMQ里面的堆積消息個(gè)數(shù),如何使用rabbitMQ獲取監(jiān)控的隊(duì)列里面的隊(duì)列消息個(gè)數(shù)呢,需要的朋友可以參考下2019-07-07解讀Spring接口方法加@Transactional失效的原因
這篇文章主要介紹了Spring接口方法加@Transactional失效的原因解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03Spring自帶的校驗(yàn)框架Validation的使用實(shí)例
今天小編就為大家分享一篇關(guān)于Spring自帶的校驗(yàn)框架Validation的使用實(shí)例,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-03-03Java NIO原理圖文分析及代碼實(shí)現(xiàn)
本文主要介紹Java NIO原理的知識(shí),這里整理了詳細(xì)資料及簡(jiǎn)單示例代碼和原理圖,有需要的小伙伴可以參考下2016-09-09