數(shù)組集合添加算法

集合是無限存儲的容器:

數(shù)組集合采用的算法是一開始先開辟好有限的空間進行存儲放進來的數(shù)據(jù)。

等需要再次存放數(shù)據(jù)的時候,再去開辟一塊比原來的空間多的容量之前,老的數(shù)據(jù)導(dǎo)入進新開辟的空間,然后再把新進來的數(shù)據(jù)放進空間里,依次這樣進行開辟導(dǎo)入就形成了無限的容器。這就是數(shù)組集合的算法。

在java源碼里面,采用的導(dǎo)入方式是直接調(diào)用本地系統(tǒng)語言來直接導(dǎo)入數(shù)據(jù),這樣提高了效率,一萬毫秒才能完成的事情也許四千毫秒就執(zhí)行完畢。

取消for循環(huán)導(dǎo)入使用System.arraycopy如下代碼:

/** * 更多資料歡迎瀏覽凱哥學(xué)堂官網(wǎng):http://kaige123.com? *@author小沫 *///把objs的數(shù)據(jù)從最開始導(dǎo)入到objs1最開始的空間進行依次存放。objs里面有多少數(shù)據(jù)那么就導(dǎo)入多少。System.arraycopy(objs,objs1,0,objs.length);

//用下標(biāo)得到數(shù)據(jù)publicObjectget(intindex){returnobjs[index];}//得到大小publicintsize(){returnindex;}

測試類:

publicstaticvoidmain(){MyArrayList list=newMyArrayList();longtem=System.currentTimeMillis();for(inti=0;i<100000;i++){list.add("abc"+i);for(intj=0;j

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

推薦閱讀更多精彩內(nèi)容

  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法,繼承相關(guān)的語法,異常的語法,線程的語...
    子非魚_t_閱讀 31,765評論 18 399
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 134,933評論 18 139
  • 貪心算法 貪心算法總是作出在當(dāng)前看來最好的選擇。也就是說貪心算法并不從整體最優(yōu)考慮,它所作出的選擇只是在某種意義上...
    fredal閱讀 9,279評論 3 52
  • 弘揚真善美,相約中國夢;代代永相傳,幽幽華夏情! 有了真善美,才有了精彩無限!你看:劉禹錫選擇了...
    霍新威閱讀 596評論 9 15
  • 無內(nèi)容
    簡書的藍葉閱讀 176評論 0 0