电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Java封裝數組之改進為泛型數組操作詳解

瀏覽:8日期:2022-09-04 17:19:39

本文實例講述了Java封裝數組之改進為泛型數組操作。分享給大家供大家參考,具體如下:

前言:通過上一節我們對我們需要封裝的數組,進行了基本的增刪改查的封裝,但只局限于int類型的操作,為了能提供多種類型數組的操作,我們可以將其進一步封裝為泛型數組。

1.定義泛型數組相關概念

(1)泛型數組讓我們可以存放任何數據類型

(2)存放的類型不可以是基本數據類型,只能是類對象

基本類型:

boolean、byte、char、short、int、long、float、double

(3)每個基本數據類型都有對應的包裝類

Boolean、Byte、Char、Short、Integer、Long、Float、Double

2.自定義泛型數組

/** * 2.泛型數組 */public class GenericArray<E> { //使用private 的目的是防止用戶從外界修改,造成數據不一致 private E[] data; private int size;//數組中元素個數 //構造函數,傳入數組的容量capacity構造Array函數 public GenericArray(int capacity) { data = (E[]) new Object[capacity];//泛型不能直接實例化 size = 0; } //無參構造函數,默認數組的容量capacity=10 public GenericArray() { this(10); } //獲取數組中元素個數 public int getSize() { return size; } //獲取數組的容量 public int getCapacity() { return data.length; } //獲取數據是否為空 public boolean iEmpty() { return size == 0; } //向所有元素后添加元素 public void addLast(E e) { add(size, e);//size表示此時的最后一個元素 } //在所有元素之前添加一個新元素 public void addFirst(E e) { add(0, e);//0表示第一個位置 } //在第index個位置插入一個新元素 public void add(int index, E e) { //(1)先判斷當前數組容量是否已滿,未滿則轉入(2),否則拋出異常 if (size == data.length) { throw new IllegalArgumentException('數組已滿'); } //(2)判斷當前需要插入值的位置是否合理,合理則轉入(3),否則拋出位置不合法異常 if (index < 0 || index > size) { throw new IllegalArgumentException('您選擇的位置不合法'); } //將index位置之后的元素往后依次移動一位 for (int i = size - 1; i >= index; i--) { //(3)將index之后的元素依次往后移動一位,然后將新元素插入到index位置 data[i + 1] = data[i]; } data[index] = e; //(4)維護size值 size++; } //獲取index索引位置的元素 public E get(int index) { //(1)判斷當前需要插入值的位置是否合理,合理則轉入(2),否則拋出位置不合法異常 if (index < 0 || index > size) throw new IllegalArgumentException('您選擇的位置不合法'); //(2)返回索引index對應的值 return data[index]; } //獲取最后一個元素 public E getLast() { return get(size - 1); } //獲取第一個元素 public E getFirst() { return get(0); } //修改index索引位置的元素為e void set(int index, E e) { //(1)判斷當前需要插入值的位置是否合理,合理則轉入(2),否則拋出位置不合法異常 if (index < 0 || index > size) throw new IllegalArgumentException('您選擇的位置不合法'); //(2)修改索引index對應的值 data[index] = e; } //查找數組中是否包含元素e public boolean contains(E e) { for (int i = 0; i < size; i++) { if (data[i] == e)return true; } return false; } //查找數組中元素e所在的索引(只是一個),如果不存在元素e,則返回-1; public int find(E e) { for (int i = 0; i < size; i++) { if (data[i] == e)return i; } return -1; } //從數組中刪除index位置的元素,返回刪除的元素 public E remove(int index) { //1.判斷索引的選擇是否合法 if (index < 0 || index > size) throw new IllegalArgumentException('您選擇的位置不合法'); //2.先存儲需要刪除的索引對應的值 E ret = data[index]; //將索引為index之后(index)的元素依次向前移動 for (int i = index + 1; i < size; i++) { //3.執行刪除--實質為索引為index之后(index)的元素依次向前移動,將元素覆蓋 data[i - 1] = data[i]; } //4.維護size變量 size--; // loitering objects != memory leak 手動釋放內存空間 data[size] = null; //5.返回被刪除的元素 return ret; } //從數組中刪除第一個元素,返回刪除的元素 public E removeFirst() { return remove(0); } //從數組中刪除最后一個元素,返回刪除的元素 public E removeLast() { return remove(size - 1); } //從數組中刪除元素(只是刪除一個) public void removeElement(E e) { int index = find(e); if (index != -1) remove(index); } @Override public String toString() { StringBuilder res = new StringBuilder(); res.append(String.format('Array:size=%d, capacity=%dn', size, data.length)); res.append(’[’); for (int i = 0; i < size; i++) { res.append(data[i]); if (i != size - 1) {res.append(','); } } res.append(’]’); return res.toString(); }}

3.測試泛型數組

public class Student { private String name; private int score; public Student(String name, int score) { this.name = name; this.score = score; } @Override public String toString() { return String.format('Student(name:%s, score:%d)', name, score); } public static void main(String[] args) { GenericArray<Student> studentArray = new GenericArray<>(); studentArray.addLast(new Student('test01', 66)); studentArray.addLast(new Student('test02', 77)); studentArray.addLast(new Student('test03', 88)); System.out.println(studentArray); }}

驗證結果如下:

Java封裝數組之改進為泛型數組操作詳解

更多關于java相關內容感興趣的讀者可查看本站專題:《Java數組操作技巧總結》、《Java字符與字符串操作技巧總結》、《Java數學運算技巧總結》、《Java數據結構與算法教程》及《Java操作DOM節點技巧總結》

希望本文所述對大家java程序設計有所幫助。

標簽: Java
相關文章:
主站蜘蛛池模板: 知网论文检测系统入口_论文查重免费查重_中国知网论文查询_学术不端检测系统 | 风化石头制砂机_方解石制砂机_瓷砖石子制砂机_华盛铭厂家 | 蜂蜜瓶-玻璃瓶-玻璃瓶厂-玻璃瓶生产厂家-徐州贵邦玻璃制品有限公司 | 校车_校车价格_19座幼儿园校车_幼儿园校车_大鼻子校车 | TwistDx恒温扩增-RAA等温-Jackson抗体-默瑞(上海)生物科技有限公司 | 环球电气之家-中国专业电气电子产品行业服务网站! | 美国PARKER齿轮泵,美国PARKER柱塞泵,美国PARKER叶片泵,美国PARKER电磁阀,美国PARKER比例阀-上海维特锐实业发展有限公司二部 | 舞台木地板厂家_体育运动木地板_室内篮球馆木地板_实木运动地板厂家_欧氏篮球地板推荐 | 氢氧化钾厂家直销批发-济南金昊化工有限公司 | 华禹护栏|锌钢护栏_阳台护栏_护栏厂家-华禹专注阳台护栏、楼梯栏杆、百叶窗、空调架、基坑护栏、道路护栏等锌钢护栏产品的生产销售。 | 不锈钢水箱生产厂家_消防水箱生产厂家-河南联固供水设备有限公司 | 河南正规膏药生产厂家-膏药贴牌-膏药代加工-修康药业集团官网 | 超声波乳化机-超声波分散机|仪-超声波萃取仪-超声波均质机-精浩机械|首页 | 聚合氯化铝_喷雾聚氯化铝_聚合氯化铝铁厂家_郑州亿升化工有限公司 | 硫化罐-电加热蒸汽硫化罐生产厂家-山东鑫泰鑫智能装备有限公司 | 六自由度平台_六自由度运动平台_三自由度摇摆台—南京全控科技 | 西门子气候补偿器,锅炉气候补偿器-陕西沃信机电工程有限公司 | 喷涂流水线,涂装流水线,喷漆流水线-山东天意设备科技有限公司 | 硫化罐_蒸汽硫化罐_大型硫化罐-山东鑫泰鑫智能装备有限公司 | 雨燕360体育免费直播_雨燕360免费NBA直播_NBA篮球高清直播无插件-雨燕360体育直播 | 2-羟基泽兰内酯-乙酰蒲公英萜醇-甘草查尔酮A-上海纯优生物科技有限公司 | 上海质量认证办理中心| 众品家具网-家具品牌招商_家具代理加盟_家具门户的首选网络媒体。 | 电镀电源整流器_高频电解电源_单脉双脉冲电源 - 东阳市旭东电子科技 | 亚克隆,RNAi干扰检测,miRNA定量检测-上海基屹生物科技有限公司 | 【MBA备考网】-2024年工商管理硕士MBA院校/报考条件/培训/考试科目/提前面试/考试/学费-MBA备考网 | 大白菜官网,大白菜winpe,大白菜U盘装系统, u盘启动盘制作工具 | 电镀标牌_电铸标牌_金属标贴_不锈钢标牌厂家_深圳市宝利丰精密科技有限公司 | 工业风机_环保空调_冷风机_工厂车间厂房通风降温设备旺成服务平台 | 食品机械专用传感器-落料放大器-低价接近开关-菲德自控技术(天津)有限公司 | 高柔性拖链电缆-聚氨酯卷筒电缆-柔性屏蔽电缆厂家-玖泰电缆 | 不锈钢闸阀_球阀_蝶阀_止回阀_调节阀_截止阀-可拉伐阀门(上海)有限公司 | sfp光模块,高速万兆光模块工厂-性价比更高的光纤模块制造商-武汉恒泰通 | 净化工程_无尘车间_无尘车间装修-广州科凌净化工程有限公司 | 直齿驱动-新型回转驱动和回转支承解决方案提供商-不二传动 | 电缆接头-防爆电缆接头-格兰头-金属电缆接头-防爆填料函 | 天长市晶耀仪表有限公司| 电力测功机,电涡流测功机,磁粉制动器,南通远辰曳引机测试台 | 奥因-光触媒除甲醛公司-除甲醛加盟公司十大品牌 | 昆明网络公司|云南网络公司|昆明网站建设公司|昆明网页设计|云南网站制作|新媒体运营公司|APP开发|小程序研发|尽在昆明奥远科技有限公司 | 蒜肠网-动漫,二次元,COSPLAY,漫展以及收藏型模型,手办,玩具的新媒体.(原变形金刚变迷TF圈) |