日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Vector和LinkedList源代码阅读笔记

發布時間:2025/4/14 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Vector和LinkedList源代码阅读笔记 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Vector

1 三個成員變量

elementData: Container

elementCount: 有效長度

capacityIncrement: 每次增加的長度

?

2, 其構造函數沒什么特別的,但是不建議使用Vector()和Vector(intialCapacity)。前者把intialCapacity的默認值設為10,并調用后者。而后者把capacityincrement設為0。覺得這樣會有性能問題。

?

3,copyInto會影響參數。

?

4 Vector提供線程安全的訪問。

?

5,ensureCapacityHelper是一個private的非線程安全的方法。作用是ensureCapacity。其他add的時候會通過這個方法保證Capacity。其實這是一個比較好的解決線程沖突的方法,外部同步,內部不同步

?

6 setSize方法,修改了elmementCount。如果newSize>elmementCount,則會把elementData大出的部分設為Null。通過這個方法,讓我感覺到。其實Vector是一個怎么說呢,邏輯上能夠快速改變長度的數組。因為其他通過改變其內在變量elementCount。而不是數組本身來提高速度。

?

7, capacity方法,返回的是elementData.length。而size方法,返回的是elementCount

?

8, Vector有一系列elmenent方法,其實就是語義上操縱數組。

?

9,很奇怪的地方,Indexof(Object,index)是線程同步的,但是indexof則不是。

?

LinkedList

1, Linkelist代表Container的是一個鏈表頭元素的引用。叫做header。而其所操縱的對象,是一個Entry。其有三個成員變量,分別是next, previous, element。是一個標準的數據結構鏈表。 且這個header,并不存數據。整體上還說。和數據結構中的鏈表特性相同。

?

2,從其構造函數上來看。linkedList是一個循環鏈表

?

3,除了頭和尾巴之外,獲得其他的元素,會很慢。因為都是需要遍歷數組的。

轉載于:https://www.cnblogs.com/chandlersong/archive/2011/12/31/2309148.html

總結

以上是生活随笔為你收集整理的Vector和LinkedList源代码阅读笔记的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。