Java ArrayList的底層實現(xiàn)方法
更新時間:2018年10月13日 08:58:08 作者:王小濤_同學(xué)
今天小編就為大家分享一篇Java ArrayList的底層實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
如下所示:
package com.soto.collection;
/**
* 自己實現(xiàn)一個ArrayList,幫助我們更好地理解ArrayList的底層結(jié)構(gòu);
* @author 王
*
*/
public class SxtArrayList {
private Object[] elementData;
private int size;
public int size(){
return size;
}
public boolean isEmpty(){
return size == 0;
}
public SxtArrayList(){
this(10);
}
public SxtArrayList(int initialCapacity){
if(initialCapacity<0){
try {
throw new Exception();
} catch (Exception e) {
e.printStackTrace();
}
}
elementData = new Object[initialCapacity]; //初始化 容量為10
}
public void add(Object obj){
elementData[size++] = obj; //若超過容量了,那么..數(shù)組擴(kuò)容
if(size==elementData.length){
//實質(zhì):搞個新數(shù)組
Object[] newarray = new Object[size*2+1];
//數(shù)組的copy:
System.arraycopy(elementData, 0, newarray, 0, elementData.length);
elementData = newarray;
}
}
public Object get(int index){
rangeCheck(index);
return elementData[index];
}
public void remove(int index){
rangeCheck(index);
//刪除指定位置對象,刪除某位置,相當(dāng)于 將后往前挪:
int numMoved = size-index-1;
if(numMoved>0){
System.arraycopy(elementData, index+1, elementData, index, numMoved);
}
}
public void remove(Object obj){
for(int i=0;i<size;i++){
if(get(i).equals(obj)){ //注意底層調(diào)用的equals方法而不是==。
remove(i);
}
}
}
private void rangeCheck(int index){
if(index<0||index>size){
try {
throw new Exception();
} catch (Exception e) {
e.printStackTrace();
}
}
}
public Object set(int index, Object obj){
rangeCheck(index);
Object oldValue = elementData[index];
elementData[index] = obj;
return oldValue;
}
public void add(int index, Object obj){
rangeCheck(index);
ensureCapacity(); //擴(kuò)容
System.arraycopy(elementData, index, elementData, index + 1,
size - index);
elementData[index] = obj;
size++;
}
private void ensureCapacity(){
//擴(kuò)容
if(size==elementData.length){
//實質(zhì):搞個新數(shù)組
Object[] newarray = new Object[size*2+1];
//數(shù)組的copy:
System.arraycopy(elementData, 0, newarray, 0, elementData.length);
elementData = newarray;
}
}
public static void main(String[] args) {
SxtArrayList list = new SxtArrayList(3);
list.add("222");
list.add("333");
list.add("444");
list.add("555");
list.add("666");
list.add("777");
System.out.println(list.size());
System.out.println(list.get(6));
}
}
以上這篇Java ArrayList的底層實現(xiàn)方法就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
詳解SpringMVC?HandlerInterceptor攔截器的使用與參數(shù)
本文主要介紹了詳解SpringMVC?HandlerInterceptor攔截器的使用與參數(shù),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01
SpringCloud-Hystrix-Dashboard客戶端服務(wù)監(jiān)控的實現(xiàn)方法
這篇文章主要介紹了SpringCloud-Hystrix-Dashboard客戶端服務(wù)監(jiān)控的實現(xiàn)方法,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-03-03
springcloud?nacos動態(tài)線程池Dynamic?tp配置接入實戰(zhàn)詳解
這篇文章主要為大家介紹了springcloud?nacos動態(tài)線程池Dynamic?tp配置接入實戰(zhàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12
Spring boot連接MySQL 8.0可能出現(xiàn)的問題
這篇文章主要給大家介紹了關(guān)于Spring boot連接MySQL 8.0可能出現(xiàn)的問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-10-10
mybatisPlus 實體類與數(shù)據(jù)庫表映射關(guān)系詳解
這篇文章主要介紹了mybatisPlus 實體類與數(shù)據(jù)庫表映射關(guān)系詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教。2022-01-01

