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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

自定义 ArrayList

發(fā)布時間:2025/5/22 编程问答 52 豆豆
生活随笔 收集整理的這篇文章主要介紹了 自定义 ArrayList 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

2019獨角獸企業(yè)重金招聘Python工程師標準>>>

英文原文

ArrayList 類似于 Array 對象,但是當列表中的對象數(shù)量增加時,它提供了動態(tài)空間分配的功能。在 Array 對象中,我們需要在初始化時提供數(shù)組的大小,但這并不是 ArrayList 所必需的。實際上,當您初始化ArrayList時,它將自動將其容量分配為10。

這里我用 Array 對象實現(xiàn)ArrayList,并提供 get(index),add(object) 和 remove(index) 等基本函數(shù)。

import java.util.ArrayList;/*** <p></p>** @author 三產(chǎn)* @version 1.0* @date 2017-03-24* @QQGroup 213732117* @website http://www.coderknock.com* @copyright Copyright 2017 拿客 coderknock.com All rights reserved.* @since JDK 1.8*/ public class MyArrayList {private static final int SIZE_FACTOR=5;private Object data[];private int index;private int size;public MyArrayList(){this.data=new Object[SIZE_FACTOR];this.size=SIZE_FACTOR;}public void add(Object obj){System.out.println("index:"+this.index+"size:"+this.size+"data size:"+this.data.length);if(this.index==this.size-1){//我們需要加大data[]的大小increaseSizeAndReallocate();}data[this.index]=obj;this.index++;}private void increaseSizeAndReallocate() {this.size=this.size+SIZE_FACTOR;Object newData[]=new Object[this.size];for(int i=0; i<data.length;i++){newData[i]=data[i];}this.data=newData;System.out.println("***index:"+this.index+"size:"+this.size+"data size:"+this.data.length);}public Object get(int i) throws Exception{if(i>this.index-1){throw new Exception("ArrayIndexOutOfBound");}if(i<0){throw new Exception("Negative Value");}return this.data[i];}public void remove(int i) throws Exception{if(i>this.index-1){throw new Exception("ArrayIndexOutOfBound");}if(i<0){throw new Exception("Negative Value");}System.out.println("Object getting removed:"+this.data[i]);for(int x=i; x<this.data.length-1;x++){data[x]=data[x+1];}this.index--;}public static void main(String[] args) throws Exception {MyArrayList mal = new MyArrayList();mal.add("0");mal.add("1");mal.add("2");mal.add("3");mal.add("4");mal.add("5");mal.add("6");mal.add("7");mal.add("8");mal.add("9");mal.remove(5);System.out.println(mal.get(7));}}

輸出如下:

index:0size:5data size:5 index:1size:5data size:5 index:2size:5data size:5 index:3size:5data size:5 index:4size:5data size:5 ***index:4size:10data size:10 index:5size:10data size:10 index:6size:10data size:10 index:7size:10data size:10 index:8size:10data size:10 index:9size:10data size:10 ***index:9size:15data size:15 Object getting removed:5 8

這只是使用 Array 基本實現(xiàn) ArrayList 的功能,只為了解其原理。還請使用 JDK 中的 ArrayList。

原文中并為實現(xiàn)泛型,我們就來補充下:

import java.util.ArrayList;/*** <p></p>** @author 三產(chǎn)* @version 1.0* @date 2017-03-24* @QQGroup 213732117* @website http://www.coderknock.com* @copyright Copyright 2017 拿客 coderknock.com All rights reserved.* @since JDK 1.8*/ public class MyArrayList<T> {private static final int SIZE_FACTOR=5;private Object data[];private int index;private int size;public MyArrayList(){this.data=new Object[SIZE_FACTOR];this.size=SIZE_FACTOR;}public void add(T obj){System.out.println("index:"+this.index+"size:"+this.size+"data size:"+this.data.length);if(this.index==this.size-1){//我們需要加大data[]的大小increaseSizeAndReallocate();}data[this.index]=obj;this.index++;}private void increaseSizeAndReallocate() {this.size=this.size+SIZE_FACTOR;Object newData[]=new Object[this.size];for(int i=0; i<data.length;i++){newData[i]=data[i];}this.data=newData;System.out.println("***index:"+this.index+"size:"+this.size+"data size:"+this.data.length);}public T get(int i) throws Exception{if(i>this.index-1){throw new Exception("ArrayIndexOutOfBound");}if(i<0){throw new Exception("Negative Value");}return (T) this.data[i];}public void remove(int i) throws Exception{if(i>this.index-1){throw new Exception("ArrayIndexOutOfBound");}if(i<0){throw new Exception("Negative Value");}System.out.println("Object getting removed:"+this.data[i]);for(int x=i; x<this.data.length-1;x++){data[x]=data[x+1];}this.index--;}public static void main(String[] args) throws Exception {MyArrayList<Integer> mal = new MyArrayList<Integer>();mal.add(0);mal.add(1);mal.add(2);mal.add(3);mal.add(4);mal.add(5);mal.add(6);mal.add(7);mal.add(8);mal.add(9);mal.remove(5);System.out.println(mal.get(7));}}

這里其實只是修改了 add(T)、get(index) 方法。

轉(zhuǎn)載于:https://my.oschina.net/coderknock/blog/866257

總結(jié)

以上是生活随笔為你收集整理的自定义 ArrayList的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 黑人玩弄人妻一区二区三区影院 | 中文字幕在线永久 | 天堂资源中文 | 国产999视频 | 天天摸天天摸 | 加勒比成人在线 | 一区国产视频 | 午夜视频1000 | 国产欧美精品aaaaaa片 | 一区二区高清视频 | 一级做a爰片久久毛片潮喷 天天透天天干 | 国产剧情一区二区三区 | 青青草国产精品 | 久久色av| 午夜国产片 | 91免费视| 久久九九视频 | 久草视频手机在线观看 | 人妻在客厅被c的呻吟 | 日韩插插| 亚洲欧美一区二区三区久久 | 免费搞黄网站 | 国产免费脚交足视频在线观看 | 一区在线观看视频 | 精品欧美色视频网站在线观看 | 亚洲一区二区三区中文字幕 | 欧美一区二区三区爽爽爽 | 神马久久久久久 | 色偷偷av男人的天堂 | 美国做爰xxxⅹ性视频 | 色久视频| 精品美女一区二区三区 | 精品久久久无码中文字幕 | 永久免费成人代码 | 五月婷婷六月丁香综合 | 一级片免费视频 | 色婷婷麻豆 | 亚洲黄色精品 | 妖精视频在线观看免费 | 99精品视频免费版的特色功能 | 国产精品一区二区三区免费看 | 亚洲欧美日韩中文在线 | 郑艳丽三级 | 欧美日韩a级片 | 96看片| 色吊丝中文字幕 | 久久综合亚洲色hezyo国产 | 特级西西444www大胆免费看 | 天天搞夜夜 | 亚洲卡一卡二 | 黄色特一级 | 欧美一区久久 | 五月中文字幕 | 无码国产69精品久久久久网站 | 四虎综合 | 干日本少妇 | 久操视频免费观看 | 久久国产黄色片 | 国产三级日本三级在线播放 | 日韩女优一区二区 | 在线观看日韩av电影 | 97涩涩网 | 黄瓜视频污在线观看 | 看特级黄色片 | 国模精品一区 | 国产日韩欧美在线播放 | 国产天堂第一区 | 成人在线观看免费 | 在线se| 91偷拍富婆spa盗摄在线 | 红桃视频成人在线 | 久久久久人妻一区精品色 | 久国产精品 | 国产日韩亚洲欧美 | 毛片女人 | 中文文字幕一区二区三三 | 1024毛片基地 | 被绑在床强摁做开腿呻吟 | 狼人伊人干 | 日本福利视频导航 | 毛片动态图| 乱日视频 | 精品乱| 亚洲一区二区三区婷婷 | 91久久精品国产91性色tv | 搞中出| 2019av视频| 91尤物在线 | 日本少妇xxxxx | 天天看天天摸 | 99在线无码精品入口 | 精品久久久久一区 | 欧美乱码精品 | 久久97精品 | 伊人久久成人 | 中文字幕第一页在线视频 | 人妻熟女aⅴ一区二区三区汇编 | 给我看高清的视频在线观看 | 天天色天天射天天干 |