摘要:傳入的構造對進行判斷,大于的情況處理一樣的,等于的話還是調用了靜態的那個空對象,小于拋出非法長度的異常。查找元素差別不大,就是返回的元素。
ArrayList類
通過自定義的arraylist類與jdk源碼里的ArrayList的實現的對比學習:
1.所需的變量:private Object[] elementData;
private int size;
private static final int DEFAULT_LENGTH=10;
private static final int DEFAULT_CAPACITY = 10;
transient Object[] elementData;
private int size;
(1)默認長度設置成static final 因為這個是不隨具體對象改變的,是屬于類的通用不變屬性。
(2)為什么要把核心數組定義成 transient 數據類型,大概是因為序列化和反序列化的過程類要自己做,不要用默認的,至于原因深入后再談。
2.構造函數1.無參構造
public MyList(){
elementData = new Object[DEALULT_LENGTH];
}
public ArrayList() {
this.elementData = DEFAULTCAPACITY_EMPTY_ELEMENTDATA;
}
private static final Object[] DEFAULTCAPACITY_EMPTY_ELEMENTDATA = {};
無參構造可以定義成static final ,沒必要每次都new一個新的空對象。
2.傳入length的構造
public MyList(int length){
elementData = new Object[length];
}
public ArrayList(int initialCapacity) {
if (initialCapacity > 0) { this.elementData = new Object[initialCapacity]; } else if (initialCapacity == 0) { this.elementData = EMPTY_ELEMENTDATA; } else { throw new IllegalArgumentException("Illegal Capacity: "+ initialCapacity); }
}
對length進行判斷,大于0的情況處理一樣的,等于0的話還是調用了靜態的那個空對象,小于0拋出非法長度的異常。
3.增加元素public void add(E obj){
Object[] newArray; if(size == elementData.length) { newArray = new Object[elementData.length + (elementData.length >> 1)]; System.arraycopy(elementData, 0, newArray, 0, elementData.length); elementData=newArray; } elementData[size++]=obj;
}
public boolean add(E e) {
ensureCapacityInternal(size + 1); // Increments modCount!! elementData[size++] = e; return true;
}
add的差別比較大,MyList的簡單邏輯:判斷目前存的size與elementData的長度的大小,如果size等于開的長度的話,再存進去會溢出,所以需要數組擴容,擴容的基本步驟:開一個新的數組,長度是原來的1.5倍(>>1就是加上了一半,這樣運算快點),將原來數組的東西拷貝到新數組的前面,將新數組指向elementData數組,把obj存進新數組里。
源碼的邏輯多了幾層判斷,最終的擴容操作邏輯也是大同小異的:
private void grow(int minCapacity) {
// overflow-conscious code int oldCapacity = elementData.length; int newCapacity = oldCapacity + (oldCapacity >> 1); if (newCapacity - minCapacity < 0) newCapacity = minCapacity; if (newCapacity - MAX_ARRAY_SIZE > 0) newCapacity = hugeCapacity(minCapacity); // minCapacity is usually close to size, so this is a win: elementData = Arrays.copyOf(elementData, newCapacity);
}
public void remove(int index){
for(int i=index+1;i}
將index后的元素前移一位,size--;
public E remove(int index) {
rangeCheck(index); modCount++; E oldValue = elementData(index); int numMoved = size - index - 1; if (numMoved > 0) System.arraycopy(elementData, index+1, elementData, index, numMoved); elementData[--size] = null; // clear to let GC do its work return oldValue;}
源碼里remove后返回了刪除的值,并且多了一個rangecheck的函數進行index判斷,因為這個功能很多地方都可以用到,相似的。
private void rangeCheck(int index) {
if (index >= size) throw new IndexOutOfBoundsException(outOfBoundsMsg(index));}
移動使用的是for循環,源碼使用了copy方法,做一個時間的測試:
5.修改元素public void set(int index,E obj){
elementData[index]=obj;}
public E set(int index, E element) {
rangeCheck(index); E oldValue = elementData(index); elementData[index] = element; return oldValue;}
也是多了一個rangecheck的判斷,然后返回了舊的的value。
6.查找元素
public E get(int index){
return (E)elementData[index];}
public E get(int index) {
rangeCheck(index); checkForComodification(); return ArrayList.this.elementData(offset + index);}
差別不大,就是返回elementdata的index元素。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/77678.html
摘要:編程思想第版這本書要常讀,初學者可以快速概覽,中等程序員可以深入看看,老鳥還可以用之回顧的體系。以下視頻整理自慕課網工程師路徑相關免費課程。 我自己總結的Java學習的系統知識點以及面試問題,目前已經開源,會一直完善下去,歡迎建議和指導歡迎Star: https://github.com/Snailclimb/Java-Guide 筆者建議初學者學習Java的方式:看書+視頻+實踐(初...
前言 聲明,本文使用的是JDK1.8 從今天開始正式去學習Java基礎中最重要的東西--->集合 無論在開發中,在面試中這個知識點都是非常非常重要的,因此,我在此花費的時間也是很多,得參閱挺多的資料,下面未必就做到日更了... 當然了,如果講得有錯的地方還請大家多多包涵并不吝在評論去指正~ 一、集合(Collection)介紹 1.1為什么需要Collection Java是一門面向對象的語言,...
摘要:的長度為什么是的冪次方多線程并發相關問題必問創建線程的種方式。什么是線程安全。盡量少通過電話面試,效果不好。通過面試官可以大概判斷這家公司的情況。 最近3個月一口氣面了十幾家公司的Java開發崗,大大小小的面試筆試加起來快20場,收獲很多。本人畢業快2年了,畢業時在學校所在的2線省會城市找了家開發公司做java的開發,前前后后做了1年半,感覺公司對技術沒有啥追求,做的項目翻來覆去就是S...
摘要:當某個類型變量只在整個參數列表的所有參數和返回值中的一處被應用了,那么根據調用方法時該處的實際應用類型來確定。即直接根據調用方法時傳遞的參數類型或返回值來決定泛型參數的類型。 標簽: java [TOC] 本文對泛型的基本知識進行較為全面的總結,并附上簡短的代碼實例,加深記憶。 泛型 將集合中的元素限定為一個特定的類型。 術語 ArrayList -- 泛型類型 ArrayLis...
閱讀 1632·2021-11-11 10:59
閱讀 2642·2021-09-04 16:40
閱讀 3677·2021-09-04 16:40
閱讀 2997·2021-07-30 15:30
閱讀 1674·2021-07-26 22:03
閱讀 3176·2019-08-30 13:20
閱讀 2240·2019-08-29 18:31
閱讀 451·2019-08-29 12:21