Java自定义长度可变数组的神仙操作

本文介绍了如何在Java中通过使用两个数组来模拟长度可变的数组,避免每次增删数据时频繁开辟新空间。通过泛型处理不同数据类型,并在数组满时按增量扩展长度。同时,提供了添加、获取、修改和删除数据的方法,以及检查数组下标越界的处理。此外,文章还包含了测试代码以验证实现的正确性。
摘要由CSDN通过智能技术生成

我们都知道数组是线性的、类型固定、内存地址连续、定长的,主要是数组一旦被定义,那么它的长度也就定下来了,只能添加有限的数据。而长度可变的数组是要将这个长度打破,实现数组数据无限增加

那么定义长度可变的数组就可以用两个数组来实现数组长度的变化。为了避免每次增加数据或删除数据时都要重新开辟空间,我先设定原数组为固定长,在当数组放满时,一次增加一定的长度,这样 节省了开辟空间的时间

因为数组里的数据类型是不确定的,所以用泛型比较好

public class MyList<E> {
   
 private int rongliang;//容量
 private int zengliang;//增量
 private int num;//数量
  
 //定义一个原数组
 //Object类包含所有的类型,所以定义数组是用Object类
 private Object[] src;
  
 //三个不同的构造方法
 public MyList(){
   
 this(10,10);
 }
  
 public MyList(int rongliang){
   
 this(rongliang,10);
 }
  
 public MyList(int rongliang,int zengliang){
   
 this.rongliang = rongliang;
 this.zengliang = zengliang;
 src = new Object[rongliang];
 }
}

在MyList中实现在数组中添加数据,要考虑到数组中的数据数量小于数组长度时,可以直接在数组为null处添加数据,但当数组的数量大于等于数组长度时,要先重新定义一个数组,长度是原数组加增量,然后再添加数据


public void add(E s){
   
 //判断数组中的数据数量num是否大于数组的长度(容量),超出则需扩容
 if(num>=src.length){
   
 //定义一个新的数组,长度是原有的长度加增量
 Object arr[] = new Object[src.length+zengliang];
 //拷贝数组数据
 System.arraycopy(arr, 0, arr, 0, src.length);
 src = arr;
 }
 //如果num不大于数组的长度,则不需扩容,直接加入
 //如果num大于等于数组长度,则需执行上面的if语句扩容,再加入数据
 //最后num++
 src[num++] = s;
 }

取出指定下标的数据,因为传入的是下标的参数,所以要判断数组的下标是否越界,抛出异常


public E get(int index){
   
 //抛出异常
 if(index<0 || index>=num){
   
 throw new IndexOutOfBoundsException("下标越界!index:"+index+",size:"+num);
 }
 //强制转换成E类型
 return (E)src[index];
 }

修改指定下标的数据,因为传入的是下标的参数,所以要判断数组的下标是否越界,抛出异常

public void modify(int index,E s){
   
 //抛出异常
 if(index<0 || index>=num){
   
 throw new IndexOutOfBoundsException("下标越界!index:"+index+",size:"+num);
 }
 src[index] = s;
 }

删除指定下标的数据,当数组中null值的长度大于等于增量时,要将数组的容量减小,防止浪费

public void delete(int index){
   
 //抛出异常
 if(index<0 || index>=num){
   
 throw new 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值