/**
* @Author:jimisun
* @Description:
* @Date:Created in 22:10 2018-07-18
* @Modified By:
*/
public class JimisunArray<E> { private E[] data;
private int size; /**
* 构造函数,传入数组的容量capacity构造Array
*
* @param capacity
*/
public JimisunArray(int capacity) {
data = (E[]) new Object[capacity];
size = 0;
} /**
* 构造函数,如果没有传入数组容量,默认数组初始值10
*/
public JimisunArray() {
this(10);
size = 0;
} /**
* 获取数组的元素个数
*
* @return
*/
public int getSize() {
return size;
} /**
* 获取数组的容量
*
* @return 数组的容量
*/
public int getCapacity() {
return data.length;
} /**
* 返回数组是否为null
*
* @return
*/
public Boolean isEmpty() {
return size == 0;
} /**
* 向所有元素后添加一个新的元素
*
* @param e
*/
public void addLast(E e) {
add(size, e);
} /**
* 向数组的头部添加一个新元素e
*
* @param e
*/
public void addFirst(E e) {
add(0, e);
} /**
* 向指定索引添加元素
*
* @param index
* @param e
*/
public void add(int index, E e) { 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++;
} /**
* 扩充数组长度
*
* @param newCapacity
*/
private void resize(int newCapacity) {
E[] newData = (E[]) new Object[newCapacity];
for (int i = 0; i < size; i++) {
newData[i] = data[i];
}
data = newData;
} /**
* 从数组中删除index位置的元素,返回删除的元素
*
* @param index
*/
public E remove(int index) {
if (index < 0 || index >= size) {
throw new IllegalArgumentException("Delete failed,Array is full, require index>0 && index<size");
}
E ret = data[index];
for (int i = index + 1; i < size; i++) {
data[i - 1] = data[i];
}
size--;
//将最后一个变量设置为null,而并不是留着,垃圾回收机制无法回收,如果重新添加一个变量就会使原来的引用解除关联,很快就会垃圾回收
data[size] = null; //进行数组的懒减弱,防止算法震荡,增加算法的复杂度
if (size == data.length / 4 && data.length / 2 != 0) {
resize(data.length / 2);
} return ret;
} /**
* 删除第一个元素
*
* @return
*/
public E removeFirst() {
return remove(0);
} /**
* 删除最后一个元素
*
* @return
*/
public E removeLast() {
return remove(size - 1);
} /**
* 从数组中删除元素e
*
* @param e
*/
public boolean removeElement(E e) {
int index = find(e);
if (index != -1) {
remove(index);
return true;
}
return false;
} /**
* 删除数组中所有的元素e
* @param e
*/
public void removeAllElement(E e) {
while (removeElement(e) == true) {
removeElement(e);
}
} /**
* 获取指定索引的值
*
* @param index
* @return
*/
public E get(int index) {
if (index < 0 || index >= size) {
throw new IllegalArgumentException("get failed ,index is illagel.");
}
return data[index];
} /**
* 修改指定位置索引的值
*
* @param index
* @param e
*/
public void set(int index, E e) {
if (index < 0 || index >= size) {
throw new IllegalArgumentException("get failed ,index is illagel.");
}
data[index] = e;
} /**
* 查找数组中是否有元素e
*
* @param e
* @return
*/
public boolean contains(int e) {
for (int i = 0; i < size; i++) {
if (data[i].equals(e)) {
return true;
}
}
return false;
} /**
* 查找数组中元素e所在的索引,如果不存在则返回-1
*
* @param e
* @return
*/
public int find(E e) {
for (int i = 0; i < size; i++) {
if (data[i].equals(e)) {
return i;
}
}
return -1;
} @Override
public String toString() {
StringBuilder res = new StringBuilder();
res.append(String.format("Array:size = %d,capacity=%d\n", 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();
} /**
* 主方法测试
*
* @param args
*/
public static void main(String[] args) {
JimisunArray<Integer> array = new JimisunArray(10);
for (int i = 0; i < 10; i++) {
array.addLast(i);
}
for (int i = 0; i < 5; i++) {
array.removeFirst();
}
System.out.print(array.toString());
} }

java手写的动态数组JimisunArray的更多相关文章

  1. 教你如何使用Java手写一个基于数组实现的队列

    一.概述 队列,又称为伫列(queue),是先进先出(FIFO, First-In-First-Out)的线性表.在具体应用中通常用链表或者数组来实现.队列只允许在后端(称为rear)进行插入操作,在 ...

  2. 教你如何使用Java手写一个基于链表的队列

    在上一篇博客[教你如何使用Java手写一个基于数组的队列]中已经介绍了队列,以及Java语言中对队列的实现,对队列不是很了解的可以我上一篇文章.那么,现在就直接进入主题吧. 这篇博客主要讲解的是如何使 ...

  3. 代理模式精讲(手写JDK动态代理)

    代理模式是一种架构型模式,表现出来就是一个类代表另一个类的功能,一般用在想对访问一个类的时候做一些控制,同时又不想影响正常的业务,这种代理模式在现实的生活中应用的也非常的广泛,我用穷举法给举几个好理解 ...

  4. java 手写 jvm高性能缓存

    java 手写 jvm高性能缓存,键值对存储,队列存储,存储超时设置 缓存接口 package com.ws.commons.cache; import java.util.function.Func ...

  5. java手写多级缓存

    多级缓存实现类,时间有限,该类未抽取接口,目前只支持两级缓存:JVM缓存(实现 请查看上一篇:java 手写JVM高性能缓存).redis缓存(在spring 的 redisTemplate 基础实现 ...

  6. 纯数据结构Java实现(1/11)(动态数组)

    我怕说这部分内容太简单后,突然蹦出来一个大佬把我虐到哭,还是悠着点,踏实写 大致内容有: 增删改查,泛型支持,扩容支持,复杂度分析.(铺垫: Java语言中的数组) 基础铺垫 其实没啥好介绍的,顺序存 ...

  7. Java手写数组栈

    public class ArrayStack{ private String[] items; //数组 private int count; //栈内元素 private int n; //栈大小 ...

  8. 使用java语言实现一个动态数组(详解)(数据结构)

    废话不多说,上代码 1.从类名开始(我真是太贴心了) public class Array<E> 首先数组类需要带有泛型,这个不多说.需要注意的是在java中,数组只能存放同一个类型的. ...

  9. 基于Apache Zookeeper手写实现动态配置中心(纯代码实践)

    相信大家都知道,每个项目中会有一些配置信息放在一个独立的properties文件中,比如application.properties.这个文件中会放一些常量的配置,比如数据库连接信息.线程池大小.限流 ...

随机推荐

  1. sql server数据库查询超时报错

    报错信息如下: 链接服务器"DBJointFrame"的 OLE DB 访问接口 "SQLNCLI10" 返回了消息 "查询超时已过期". ...

  2. Linux 用C语言判断文件和文件夹

    Linux 用C语言判断文件和文件夹 #include <stdio.h> #include <stdlib.h> #include <unistd.h> #inc ...

  3. android:Notification实现状态栏的通知

    在使用手机时,当有未接来电或者新短消息时,手机会给出响应的提示信息,这些提示信息一般会显示到手机屏幕的状态栏上. Android也提供了用于处理这些信息的类,它们是Notification和Notif ...

  4. linux中使用lftp上传下载文件

    lftp是linux中一款ftp服务器相比windows中的ftp显得要复杂不少了,下面我来总结一下lftp文件上传,文件下载,及文件查找等等相关命令吧. lftp连接的几种方法,最常用的是lftp ...

  5. Sphider + SCWS 打造完美PHP中文搜索引擎

    今日需要为几个网站做个全文搜索引擎,找了几个PHP开源项目,先试了一下Sphinx ,可惜是基于数据库的,相当于数据库搜索的扩展.Sphider还不错,不过中文的分词不行,基本只能靠空格和符号进行分词 ...

  6. Nginx设置expires设定页面缓存时间 不缓存或一直使用缓存

    配置expires expires起到控制页面缓存的作用,合理的配置expires可以减少很多服务器的请求 要配置expires,可以在http段中或者server段中或者location段中加入 l ...

  7. 安装CentOS版本的yum(转载)

    安装CentOS版本的yum 下载源:http://mirrors.163.com/centos/6/os/i386/Packages/ 材料准备: python-iniparse-0.3.1-2.1 ...

  8. mysql5.5和5.6版本间的坑

    mysql 5.5 int类型 设置不为null,无填充,添加新数据会自动填充0 而5.6同样的配置新建数据没值时,不让添加 5.5 datetime 不能设置默认时间(可以通过某些复杂的方式,这里说 ...

  9. buildroot 修改root密码后无法登录ssh解决方法

    客户说想修改root密码后再登录ssh, 研究了一下,是因为ssh登录是匹配了之前的 密码生成文件,只要把之前的密码生成文件删除就可以. 过程如下: 删除 /etc/ssh/ssh_host*. rm ...

  10. 二、thinkphp

    ## ThinkPHP 3.1.2 查询方式#讲师:赵桐正微博:http://weibo.com/zhaotongzheng 本节课大纲:一.普通查询方式 a.字符串 $arr=$m->wher ...