广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Java 自定义动态数组方式
  • 118
分享到

Java 自定义动态数组方式

2024-04-02 19:04:59 118人浏览 独家记忆

Python 官方文档:入门教程 => 点击学习

摘要

Java自定义动态数组 1、静态数组向动态数组转变 (1)静态数组,数组空间固定长度 这个数组空间总长为4,如果此时新插入一个数据就会报数组空间不足 (2)静态数组如何转变成动态数

Java自定义动态数组

1、静态数组向动态数组转变

(1)静态数组,数组空间固定长度

这个数组空间总长为4,如果此时新插入一个数据就会报数组空间不足

(2)静态数组如何转变成动态数组

第一步:创建一个空间是data数组两倍的newData数组(扩容);

第二步:把data数组中的元素全部赋值到newData数组;

2、数组扩容程序


// 数组扩容
private void resize(int newCapacity){
  E[] newData = (E[]) new Object[newCapacity];
  for (int i = 0; i < size; i++) {
    newData[i] = data[i];
  }
  data = newData;
}

数组添加元素:数组空间不够就会扩容(原来空间2倍)


  // 数组指定位置添加元素
  public void add(int index, E e) {
//    if (size == data.length)
//      throw new IllegalArgumentException("Add failed.Array is full.");
    if (index < 0 || index > size)
      throw new IllegalArgumentException("Add failed. Require index >= 0 and index <= size");
    if (size == data.length)
      resize(2 * data.length);
    for (int i = size - 1; i >= index; i--)
      data[i + 1] = data[i];
    data[index] = e;
    size++;
  }

数组删除元素:数组空间空闲太大就会缩容(原来空间的1/2)


// 从数组中删除index位置的元素,返回删除的元素
public E remove(int index) {
  if (index < 0 || index >= size) {
    throw new IllegalArgumentException("Remove failed.Index is illegal");
  }
  E ret = data[index];
  for (int i = index + 1; i < size; i++) {
    data[i - 1] = data[i];
  }
  size--;
  // loitering objects != memory leak 手动释放内存空间
  data[size] = null;
  if(size == data.length / 2) {
    resize(data.length / 2);
  }
  return ret;
}

3、数组整体代码


public class Array<E> {
  // 定义数组变量,data.length表示数组容量capacity
  private E[] data;
  // 定义数组中存放数据大小
  private int size;
  // 有参构造方法,传入数组的容量capacity构造动态数组
  public Array(int capacity) {
    data = (E[])new Object[capacity];
    size = 0;
  }
  // 无参构造方法,默认初始容量为capacity=10
  public Array() {
    this(10);
  }
  // 获取数组中元素个数
  public int getSize() {
    return size;
  }
  // 获取数组的容量
  public int getCapacity() {
    return data.length;
  }
  // 判断数组是否为空
  public boolean isEmpty() {
    return size == 0;
  }

  // 在数组末尾添加元素(复用add方法)
  public void addLast(E e) {
    add(size, e);
  }
  // 在数组头部添加元素(复用add方法)
  public void addFirst(E e) {
    add(0, e);
  }
  // 数组指定位置添加元素
  public void add(int index, E e) {
//    if (size == data.length)
//      throw new IllegalArgumentException("Add failed.Array is full.");
    if (index < 0 || index > size)
      throw new IllegalArgumentException("Add failed. Require index >= 0 and index <= size");
    if (size == data.length)
      resize(2 * data.length);
    for (int i = size - 1; i >= index; i--)
      data[i + 1] = data[i];
    data[index] = e;
    size++;
  }
  // 获取index索引位置的元素
  public E get(int index) {
    if (index < 0) {
      throw new IllegalArgumentException("Get failed.Index is illegal.");
    }
    return data[index];
  }
  // 修改index索引位置的元素
  public void set(int index, E e) {
    if (index < 0 || index >= size) {
      throw new IllegalArgumentException("Set failed.Index is illegal.");
    }
    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) {
    if (index < 0 || index >= size) {
      throw new IllegalArgumentException("Remove failed.Index is illegal");
    }
    E ret = data[index];
    for (int i = index + 1; i < size; i++) {
      data[i - 1] = data[i];
    }
    size--;
    // loitering objects != memory leak 手动释放内存空间
    data[size] = null;
    if(size == data.length / 2) {
      resize(data.length / 2);
    }
    return ret;
  }
  // 删除数组第一个元素,返回删除的元素
  public E removeFirst() {
    return remove(0);
  }
  // 删除数组最后一个元素
  public E removeLast() {
    return remove(size - 1);
  }
  // 删除数组中指定元素e
  public void removeElement(E e) {
    int index = find(e);
    if (index != -1) {
      remove(index);
    }
  }
  // 数组扩容
  private void resize(int newCapacity){
    E[] newData = (E[]) new Object[newCapacity];
    for (int i = 0; i < size; i++) {
      newData[i] = data[i];
    }
    data = newData;
  }
  // 重写父类toString()方法
  @Override
  public String toString() {
    StringBuilder sb = new StringBuilder();
    sb.append(String.fORMat("Array: size = %d , capacity = %d\n", size, data.length));
    sb.append('[');
    for (int i = 0; i < size; i++) {
      sb.append(data[i]);
      if (i != size - 1) {
        sb.append(',');
      }
    }
    sb.append(']');
    return sb.toString();
  }
}

4、数组测试代码


public class ArrayTest {
  public static void main(String[] args) {
    // 测试toString()方法
    Array<Integer> arr = new Array(10);
    for (int i = 0; i < 10; i++) {
      // 测试addLast(int e)方法
      arr.addLast(i);
    }
    System.out.println("添加数组元素:");
    System.out.println(arr);
    // 测试add(int index, int e)方法
    arr.add(1, 200);
    System.out.println("在数组指定索引位置插入元素e:");
    System.out.println(arr);
    // 测试addFirst(int e)方法
    arr.addFirst(-10);
    System.out.println("在数组头部位置插入元素e:");
    System.out.println(arr);
  }
}

测试结果如下所示:初始化数组空间大小为10,第一次插入10个元素到数组之后,然后再添加一个元素,此时数组会扩容为原来空间的两倍。

添加数组元素:


Array: size = 10 , capacity = 10
[0,1,2,3,4,5,6,7,8,9]

在数组指定索引位置插入元素e:


Array: size = 11 , capacity = 20
[0,200,1,2,3,4,5,6,7,8,9]

在数组头部位置插入元素e:


Array: size = 12 , capacity = 20

补充:Java静态数组和动态数组的定义方式

数组的定义方式

静态:


//简化语法常用 定义和初始化同步完成
int [] a = {5,2,6,4,10};

动态:


//数组的定义和初始化同时完成,使用动态初始化语法
int[] prices = new int[5];

补充:


//初始化数组时元素的类型是定义数组时元素类型的子类
Object[] books = new String[4];

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

--结束END--

本文标题: Java 自定义动态数组方式

本文链接: https://www.lsjlt.com/news/122369.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Java 自定义动态数组方式
    Java自定义动态数组 1、静态数组向动态数组转变 (1)静态数组,数组空间固定长度 这个数组空间总长为4,如果此时新插入一个数据就会报数组空间不足 (2)静态数组如何转变成动态数...
    99+
    2022-11-11
  • Java动态数组Arraylist存放自定义数据类型方式
    目录Java动态数组Arraylist存放自定义数据类型自定义一个动态数组ArrayList,加深对动态数组的理解Java动态数组Arraylist存放自定义数据类型 class...
    99+
    2022-11-12
  • 怎么在Java中自定义动态数组
    这期内容当中小编将会给大家带来有关怎么在Java中自定义动态数组,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。Java的特点有哪些Java的特点有哪些1.Java语言作为静态面向对象编程语言的代表,实现了...
    99+
    2023-06-14
  • java动态数组定义的方法是什么
    在Java中,可以使用以下两种方法定义动态数组:1. 使用ArrayList类:ArrayList是Java中提供的一个动态数组类,...
    99+
    2023-10-20
    java
  • Android自定义组件:1、什么是自定义组件、自定义组件的方式、定义自定义属性
    声明:本教程不收取任何费用,欢迎转载,尊重作者劳动成果,不得用于商业用途,侵权必究!!! 目录 一、前言 二、什么是自定义组件 三、自定义组件的方式 1、组合现有组件 2、在某...
    99+
    2022-06-06
    属性 自定义属性 Android
  • vue自定义动态组件的方法是什么
    本篇内容主要讲解“vue自定义动态组件的方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“vue自定义动态组件的方法是什么”吧! Vue.extend 思路就是拿到组件...
    99+
    2023-07-04
  • vue2 中怎么自定义动态组件
    vue2 中怎么自定义动态组件,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。 Vue.extend 思路就是拿到组件的构造...
    99+
    2022-10-19
  • Vue中怎么自定义动态组件
    Vue中怎么自定义动态组件,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。举第一个栗子用vue-cli搭建好项目目录之后,在src/compon...
    99+
    2022-10-19
  • vue3自定义hooks/可组合函数方式
    目录自定义hooks/可组合函数1.mixins方式的痛点2.传统mixins方式示例3.自定义hooks方式示例vue3(hooks)自定义hooks/可组合函数 vue3 com...
    99+
    2022-11-13
  • java启动时自定义配置文件路径,自定义log4j2.xml位置方式
    目录java启动时自定义配置文件路径,自定义log4j2.xml位置启动时指定配置文件位置有一种说法:说配置文件加载顺序为(由高到低)经验证后来又发现一个问题如果启动不了java服务...
    99+
    2022-11-13
  • java自定义切面增强方式(关于自定义注解aop)
    目录java自定义切面增强切面、自定义注解的使用AOP简介AOP定义注解简介元素和组成元注解总结java自定义切面增强 写代码时会遇到一些有些重复机械的工作, 这个时候就可以运用切面...
    99+
    2023-05-14
    java自定义切面增强 自定义注解aop java切面
  • java怎么自定义数组添加数据
    在Java中,可以通过以下几种方式自定义数组添加数据:1. 使用循环逐个添加数据:通过使用循环,可以逐个向数组中添加数据。首先需要创...
    99+
    2023-09-26
    java
  • php定义数组有几种方式
    在PHP中,有三种常见的方式来定义数组:1. 索引数组:使用数字作为索引的数组。可以通过在方括号中指定索引位置来定义。```php$...
    99+
    2023-08-28
    PHP
  • mybatis自动扫描和自定义类注解方式
    目录mybatis自动扫描和自定义类注解Spring mybatis自动扫描dao解决方案mybatis自动扫描和自定义类注解 以往都是使用自定义注解实现Dao层mapper.jav...
    99+
    2022-11-12
  • java怎么自定义函数式接口
    这篇文章给大家分享的是有关java怎么自定义函数式接口的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1、说明只包含抽象方法的界面,称为函数界面。可以通过Lambda表达式创建该界面的对象。如果Lambda表达式抛...
    99+
    2023-06-15
  • SpringBoot自定义动态切换数据源的方法是什么
    本篇内容主要讲解“SpringBoot自定义动态切换数据源的方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“SpringBoot自定义动态切换数据源的方法是什么”吧!1、添加maven依...
    99+
    2023-06-21
  • SpringBoot自定义+动态切换数据源教程
    目录1、添加maven依赖2、配置application.yml3、配置动态数据源4、配置数据源操作Holder5、读取自定义数据源,并配置6、动态切换关键——AOP进行切换7、使用...
    99+
    2022-11-12
  • Java如何自定义一个变长数组
    这篇文章主要介绍“Java如何自定义一个变长数组”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java如何自定义一个变长数组”文章能帮助大家解决问题。思路分析主要功能点:新建时可以指定容量大小,不指...
    99+
    2023-07-04
  • c语言二维动态数组怎么定义
    在C语言中,定义一个二维动态数组可以使用指针的指针来实现。下面是一个示例代码: #include #include int m...
    99+
    2023-10-27
    c语言
  • Java中的自定义异常捕获方式
    目录Java 自定义异常捕获自定义异常类格式如下:自定义异常类的调用格式如下:可能出现异常的代码写法如下:本题完整代码如下:自定义异常Exception根据业务需要不用的异常打印不用类型的日志Java 自定义异常捕获 编写一个程序,将字符串...
    99+
    2016-05-06
    Java异常 自定义异常 异常捕获
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作