亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

ArrayList分析

2019-11-10 20:52:02
字體:
來源:轉載
供稿:網友

ArrayList應該是最常用的容器吧,使用非常簡單,那我就從源碼簡單分析下。 首先看看ArrayList的繼承體系: 這里寫圖片描述 先說說其對這些接口的支持吧,

Serializable 一個標記,表明實現此接口的類具有序列化的能力。Cloneable 一個標記,表明實現此接口的類能夠調用 java.lang.Object.clone()方法,不然會拋出CloneNotSupportedException; 對于Cloneable接口,需要注意一點,屬于淺度復制,使用時需要注意,對于引用類型的字段,只會復制引用。public class T01 implements Cloneable{ int i = 3; Object o = 3; public static void main(String[] args) throws CloneNotSupportedException { T01 t = new T01(); T01 t1 = (T01)t.clone(); System.out.PRintln(t1.i == t.i); System.out.println(t1.o == t.o); }}

打?。?/p>truetrue

證明不同引用類型指向同一處內存空間。 我們來看下ArrayList對于clone的支持,先看源碼:

public Object clone() { try { @SuppressWarnings("unchecked") ArrayList<E> v = (ArrayList<E>) super.clone(); v.elementData = Arrays.copyOf(elementData, size); //集合的內容進行了深度拷貝 v.modCount = 0; return v; } catch (CloneNotSupportedException e) { // this shouldn't happen, since we are Cloneable throw new InternalError(); } }

使用ArrayList的clone能夠獲得和當前引用完全相同的數據。這種寫法,對于我們有很重要的借鑒意義,通常實現Cloneable接口的類,最好的做法就是如同上面的代碼一樣,提供公有的非受檢clone方法。對于ArrayList本身的這個方法,估計會用的比較少,因為實現與接口分離的思想,大多數人都會這么寫:

List<Integer> list = new ArrayList<Integer>()

而List接口是不提供克隆方法的。

Randomaccess 這個估計一般都會被忽視,主要作用是表示實現此接口的類,應用隨機訪問比使用迭代器會有更好的性能。下面段代碼來自Collections public static <T> void fill(List<? super T> list, T obj) { int size = list.size(); if (size < FILL_THRESHOLD || list instanceof RandomAccess) { for (int i=0; i<size; i++) list.set(i, obj); } else { ListIterator<? super T> itr = list.listIterator(); for (int i=0; i<size; i++) { itr.next(); itr.set(obj); } } }

一般情況對于ArrayList都應該使用迭代器進行遍歷,不容易出錯,尤其應該使用foreach語法。在性能和代碼清晰與簡單上比較,不是特殊情況,都應該偏向后者,畢竟簡單清晰的東西會很容易理解,就算有問題也容易優化。寫代碼也應該是這種思路,清晰簡單的實現最佳,如果難以看出代碼的意圖,那么就難以保護其中的設計,更難以維護。

閑扯到此為止,現在進入主題。 ArrayList其實就是長度可變的數組,數據長度不是固定的嗎,如何進行擴容呢,沒辦法,只能重新new一個數組,然后把現有的東西復制進去。這就是ArrayList實現的原理。 從上面可以看出,性能的優化點主要在減少數據復制或者不復制,怎么辦,初始化合理的數組長度,會有助于性能優化。

public ArrayList(int initialCapacity) { super(); if (initialCapacity < 0) throw new IllegalArgumentException("Illegal Capacity: "+ initialCapacity); this.elementData = new Object[initialCapacity]; }

對于ArrayList討論最多的也就是并發環境下的異常:ConcurrentModificationException,那么什么情況下會拋出呢,看源碼:

@SuppressWarnings("unchecked") public E next() { checkForComodification(); int i = cursor; if (i >= size) throw new NoSuchElementException(); Object[] elementData = ArrayList.this.elementData; if (i >= elementData.length) throw new **ConcurrentModificationException**(); cursor = i + 1; return (E) elementData[lastRet = i]; }final void checkForComodification() { if (modCount != expectedModCount) throw new ConcurrentModificationException(); }

這是遍歷器的部分源碼,大致可以看出modCount != expectedModCount時拋出異常,expectedModCount是在內部類初始化的時候賦值外部類的modCount 。當兩值不同時,肯定是有些操作改變了外部類的modCount ,那是哪些方法呢。 分析源碼發現,只要是引起底層數組長度變化的方法,都會改變modCount,都有可能拋出異常,為什么是有可能呢?因為沒有正確的同步,其他線程對modCount值的改變可能對執行遍歷的線程不可見,這也是兼顧性能后做出的最大的努力,快速失敗(fail-fast)。 所以在并發的環境有寫操作,ArrayList有很大的風險,會造成遍歷的失敗,對于并發使用,JUC中提供了CopyOnWriteArrayList,遍歷開始指向原數組空間,寫的時候復制原數組形成新數組,最后賦值給原數組引用,由于遍歷器是指向的原數組地址空間,寫操作并不會對遍歷產生影響。 但是具體如何使用,還得具體問題具體分析,只有熟悉了各自的不足,才能正確的規避。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品久久久久国产| 午夜精品久久久久久久男人的天堂| 亚洲男人天堂网站| 97在线观看视频国产| 国产精品嫩草视频| 欧美极品少妇xxxxx| 丝袜一区二区三区| 亚洲欧美一区二区三区四区| 久久久国产成人精品| 中文字幕成人精品久久不卡| 亚洲成人精品视频| 日韩中文字幕在线播放| 热久久美女精品天天吊色| 精品中文字幕在线| 亚洲精品视频在线观看视频| 亚洲国产一区二区三区在线观看| 久久天堂av综合合色| 国产精品88a∨| 国产一区二区在线免费视频| 亚洲娇小xxxx欧美娇小| 亚洲激情视频在线| 中文字幕精品一区久久久久| www国产91| 911国产网站尤物在线观看| 欧美整片在线观看| 久久国产精品久久久久久久久久| 中文字幕欧美日韩va免费视频| …久久精品99久久香蕉国产| 亚洲一区二区三区乱码aⅴ| 一个人看的www久久| 国产成人精品优优av| 国产精品久久久久久久久借妻| 成人午夜两性视频| 国产一区二区精品丝袜| 国产精品久久久久久网站| 美女扒开尿口让男人操亚洲视频网站| 米奇精品一区二区三区在线观看| 日韩在线观看免费| 欧美日韩国内自拍| 国产a∨精品一区二区三区不卡| 亚洲最大av网站| 欧美精品videos| 欧美视频国产精品| 亚洲成**性毛茸茸| 国产福利成人在线| 国产精品中文字幕在线| 亚洲综合中文字幕68页| 日日狠狠久久偷偷四色综合免费| 国产午夜精品视频| 日韩美女av在线| 2019中文字幕在线免费观看| 日本在线精品视频| 亚洲free嫩bbb| 欧美日韩国产成人高清视频| 亚洲欧洲日产国码av系列天堂| 欧美贵妇videos办公室| 国产午夜精品久久久| 欧美成人激情视频| 日韩欧美在线网址| 国产精品久久久久久久久久小说| 欧美激情喷水视频| 久久精品国产成人| 粗暴蹂躏中文一区二区三区| 国产精品丝袜久久久久久不卡| 久久久久久高潮国产精品视| 久久精品99久久香蕉国产色戒| 欧美成年人视频网站| 亚洲成人久久久久| 国内精品久久久久影院 日本资源| 欧美日韩亚洲国产一区| 欧美大人香蕉在线| 国产精品久久久久久久久免费| 亚洲少妇激情视频| 4438全国成人免费| 国产成人免费91av在线| 亚洲精品成人av| 精品一区二区三区电影| 少妇av一区二区三区| 午夜精品久久久久久久男人的天堂| 欧美激情亚洲激情| 亚洲深夜福利网站| 亚洲丝袜一区在线| 国产一区二区视频在线观看| 在线视频日韩精品| 欧美日韩免费区域视频在线观看| 国产a级全部精品| 国产免费一区二区三区在线能观看| 久久久噜噜噜久久久| 精品国产一区二区三区在线观看| 日韩电影大片中文字幕| 亚洲国产欧美一区二区三区久久| 亚洲欧美福利视频| 国产精品综合久久久| 亚洲成人三级在线| 欧美日韩在线视频一区二区| 亚洲日本中文字幕| 在线视频免费一区二区| 91av免费观看91av精品在线| 国产精品免费在线免费| 成人中文字幕+乱码+中文字幕| 国产脚交av在线一区二区| 九九热这里只有精品6| 中文字幕精品一区二区精品| 在线性视频日韩欧美| 国产精品久久久久77777| 久久精品国产精品| 色www亚洲国产张柏芝| 欧美午夜美女看片| 国产成人综合av| 久久久精品网站| 国产精品女人网站| 欧美国产日韩一区二区在线观看| 精品国产自在精品国产浪潮| 日本不卡免费高清视频| 日韩精品免费在线播放| 亚洲成人亚洲激情| 日韩www在线| 欧美日韩激情视频| 国产精品美女久久| 欧美一级bbbbb性bbbb喷潮片| 91在线直播亚洲| 亚洲成人性视频| 久久久久九九九九| 成人激情视频免费在线| 欧美午夜www高清视频| 一夜七次郎国产精品亚洲| 欧美性生交xxxxxdddd| 亚洲aa中文字幕| 国产日韩在线免费| 欧美性在线观看| 久久久久久久97| 日韩欧美a级成人黄色| 97色在线观看免费视频| 7777kkkk成人观看| 欧美成人免费小视频| 精品亚洲aⅴ在线观看| 欧美性猛交视频| 久久69精品久久久久久久电影好| 亚洲女成人图区| 日韩成人在线观看| 国产精品成人播放| 国产精品青青在线观看爽香蕉| 91精品久久久久久久久久久| 日韩在线观看你懂的| 8x海外华人永久免费日韩内陆视频| 国产成人亚洲综合青青| 欧美老女人性视频| 国产精品r级在线| 欧美亚洲第一区| 久久久亚洲欧洲日产国码aⅴ| 97精品国产97久久久久久免费| 亚洲第一黄色网| 黄色成人av网| 国产精品久久不能| 国产精品自产拍在线观看| 欧美大片在线影院| 精品一区二区三区四区在线| 成人乱人伦精品视频在线观看| 在线成人一区二区| 日韩免费在线播放| 欧美激情精品久久久久久大尺度| 久久精品视频免费播放| 38少妇精品导航| 久久五月天综合|