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

 更新时间:2021年02月04日 09:49:10   作者:miss_rong  
这篇文章主要介绍了Java自定义长度可变数组的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

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

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

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

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 IndexOutOfBoundsException("下标越界!index:"+index+",size:"+num);
 }
 //将>index的数据依次向前移动一位
 System.arraycopy(src, index+1, src, index, num-index-1);
 num--;
 //减少容量的方法
 if(src.length-num>=zengliang){
   //定义一个新的数组,长度是原先数组的长度减去增量
     Object arr[] = new Object[src.length-zengliang];
   //拷贝数组
     System.arraycopy(src, 0, arr, 0, num);
   src = arr;
 }
 }

将指定下标处的数据改为指定的数据

public void insert(int index,E s){
 //抛出异常
 if(index<0 || index>=num){
 throw new IndexOutOfBoundsException("下标越界!index:"+index+",size:"+num);
 }
 //判断数组中的数据数量num是否大于数组的长度(容量),超出则需扩容
 if(num>=src.length){
   //定义一个新的数组,长度是原有的长度加增量
   Object arr[] = new Object[src.length+zengliang];
   //拷贝数组数据
   System.arraycopy(src, 0, arr, 0, src.length);
   src = arr;
 }
 //将>index的数据依次向后移动一个位置
 //arraycopy()是可以将数据自己拷贝给自己
 System.arraycopy(src, index, src, index+1, num-index);
 //插入数据
 src[index] = s;
 num++;
 }

最后在写个获取数组中数据的个数,而不是数组的长度

public int size(){
   return num;
 }

写个测试类,来测试这个长度可变的数组是否可行

public class test {
 
 public static void main(String[] args) {
 //创建一个MyList对象
 // 在创建对象时明确类型
 MyList<String> list = new MyList<String>();
 
 //添加数据
 list.add("a");
 list.add("b");
 list.add("c");
 list.add("d");
 list.add("e");
 list.add("f");
 list.add("g");
 list.add("h");
 list.add("i");
 list.add("j"); 
 
 //遍历数组
 for(int i=0;i<list.size();i++){
 String s = list.get(i);
 System.out.print(s+" ");
 }
 
 System.out.println("");
 int n = list.size();
   System.out.println("数据个数为:"+n);
 System.out.println("**********************************************");
 
 //修改指定位置的数据
 list.modify(1, "QQ");
 
 //遍历数组
 for(int i=0;i<list.size();i++){
 String s = list.get(i);
 System.out.print(s+" ");
 }
 
 System.out.println("");
 int m = list.size();
 System.out.println("数据个数为:"+m);
 System.out.println("**********************************************");
 
 //删除指定位置的数据
 list.delete(2);
 
 //遍历数组
 for(int i=0;i<list.size();i++){
 String s = list.get(i);
 System.out.print(s+" ");
 }
 
 System.out.println("");
   int k = list.size();
   System.out.println("数据个数为:"+k);
 System.out.println("**********************************************");
 
 //在指定位置插入指定的数据
 list.insert(3, "zr");
 list.insert(3, "qi");
 
 //遍历数组
 for(int i=0;i<list.size();i++){
 String s = list.get(i);
 System.out.print(s+" ");
 }
 
 System.out.println("");
 int h = list.size();
   System.out.println("数据个数为:"+h);
 System.out.println("**********************************************");
 }
 
}

最终数组的结果为:

a b c d e f g h i j 
数据个数为:10
**********************************************
a QQ c d e f g h i j 
数据个数为:10
**********************************************
a QQ d e f g h i j 
数据个数为:9
**********************************************
a QQ d qi zr e f g h i j 
数据个数为:11
**********************************************

补充:在Java中创建一个自定义长度的数组并输入每个元素

用到知识点:数组、方法、Scanner、for循环。

作业:

package Array;
import java.util.Scanner;
public class InputArray {
public static void main(String[] args) {
shuzu();//方法调用 
 }
 //方法定义
 public static void shuzu() {
 
 //将输入的数字作为数组的长度
 Scanner sz = new Scanner(System.in);
 System.out.println("请输入数组长度:");//提示可以操作
 int[] cd = new int[sz.nextInt()];//数组初始化完成
 System.out.println("当前数组长度定义为:"+cd.length);//再提示一下结果
 
 //用for循环为每一个元素赋值
 for (int i = 0; i < cd.length; i++) {
  int q = i+1;//这里q用作提示,避免提示出第0个元素。
  System.out.println("请输入第"+q+"个元素的值:");
  cd [i] = sz.nextInt();
  System.out.println("第"+q+"个元素定义为"+cd[i]+"。"); 
  }
  sz.close();
  
  //数组内各元素已经完成赋值,但是再用for循环遍历一次
 System.out.print("数组内元素全部完成赋值:");//继续提示一下
 for (int i2 = 0; i2 < cd.length; i2++) {  
  if(i2 == cd.length-1) {
  System.out.print(cd[i2]+"。");
  }else {
  System.out.print(cd[i2]+"、");
  }
 }
 return;//方法结束,rentun;
 }
 
}

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。如有错误或未考虑完全的地方,望不吝赐教。

相关文章

  • spring-boot实现增加自定义filter(新)

    spring-boot实现增加自定义filter(新)

    本篇文章主要介绍了spring-boot实现增加自定义filter(新),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • 关于Springboot+gateway整合依赖并处理依赖冲突问题

    关于Springboot+gateway整合依赖并处理依赖冲突问题

    这篇文章主要介绍了Springboot+gateway整合依赖并处理依赖冲突问题,给大家提到了spring boot版本和spring cloud版本,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-01-01
  • SpringBoot整合Shiro实现登录认证的方法

    SpringBoot整合Shiro实现登录认证的方法

    这篇文章主要介绍了SpringBoot整合Shiro实现登录认证的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-02-02
  • Spring MVC基于注解的使用之JSON数据处理的方法

    Spring MVC基于注解的使用之JSON数据处理的方法

    这篇文章主要介绍了Spring MVC基于注解的使用JSON数据处理,json是一种轻量级的数据交换格式,是一种理想的数据交互语言,它易于阅读和编写,同时也易于机器解析和生成,本文通过实例代码给大家介绍的非常详细,需要的朋友可以参考下
    2022-05-05
  • RPC框架之Thrift的入门教程

    RPC框架之Thrift的入门教程

    Thrift是一个跨语言的服务部署框架,主要用于各个服务之间的RPC通信,支持跨语言,下面小编就来和大家讲讲Thrift框架的具体使用,希望对大家有所帮助
    2023-10-10
  • SpringBoot2 实现JPA分页和排序分页的案例

    SpringBoot2 实现JPA分页和排序分页的案例

    这篇文章主要介绍了SpringBoot2 实现JPA分页和排序分页的案例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2021-01-01
  • java swing实现简单的五子棋游戏

    java swing实现简单的五子棋游戏

    这篇文章主要为大家详细介绍了java swing实现简单的五子棋游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-03-03
  • Springboot访问html页面步骤解析

    Springboot访问html页面步骤解析

    这篇文章主要介绍了Springboot访问html页面过程解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-06-06
  • 最新版Eclipse安装、配置图文教程详解

    最新版Eclipse安装、配置图文教程详解

    这篇文章主要介绍了新版Eclipse安装、配置,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-08-08
  • Java中split根据"."分割字符串问题举例

    Java中split根据"."分割字符串问题举例

    split表达式其实就是一个正则表达式,* | . ^ 等符号在正则表达式中属于一种有特殊含义的字符,下面这篇文章主要给大家介绍了关于Java中split根据“.“分割字符串问题的相关资料,需要的朋友可以参考下
    2022-10-10

最新评论