java手写的动态数组JimisunArray
/**
* @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的更多相关文章
- 教你如何使用Java手写一个基于数组实现的队列
一.概述 队列,又称为伫列(queue),是先进先出(FIFO, First-In-First-Out)的线性表.在具体应用中通常用链表或者数组来实现.队列只允许在后端(称为rear)进行插入操作,在 ...
- 教你如何使用Java手写一个基于链表的队列
在上一篇博客[教你如何使用Java手写一个基于数组的队列]中已经介绍了队列,以及Java语言中对队列的实现,对队列不是很了解的可以我上一篇文章.那么,现在就直接进入主题吧. 这篇博客主要讲解的是如何使 ...
- 代理模式精讲(手写JDK动态代理)
代理模式是一种架构型模式,表现出来就是一个类代表另一个类的功能,一般用在想对访问一个类的时候做一些控制,同时又不想影响正常的业务,这种代理模式在现实的生活中应用的也非常的广泛,我用穷举法给举几个好理解 ...
- java 手写 jvm高性能缓存
java 手写 jvm高性能缓存,键值对存储,队列存储,存储超时设置 缓存接口 package com.ws.commons.cache; import java.util.function.Func ...
- java手写多级缓存
多级缓存实现类,时间有限,该类未抽取接口,目前只支持两级缓存:JVM缓存(实现 请查看上一篇:java 手写JVM高性能缓存).redis缓存(在spring 的 redisTemplate 基础实现 ...
- 纯数据结构Java实现(1/11)(动态数组)
我怕说这部分内容太简单后,突然蹦出来一个大佬把我虐到哭,还是悠着点,踏实写 大致内容有: 增删改查,泛型支持,扩容支持,复杂度分析.(铺垫: Java语言中的数组) 基础铺垫 其实没啥好介绍的,顺序存 ...
- Java手写数组栈
public class ArrayStack{ private String[] items; //数组 private int count; //栈内元素 private int n; //栈大小 ...
- 使用java语言实现一个动态数组(详解)(数据结构)
废话不多说,上代码 1.从类名开始(我真是太贴心了) public class Array<E> 首先数组类需要带有泛型,这个不多说.需要注意的是在java中,数组只能存放同一个类型的. ...
- 基于Apache Zookeeper手写实现动态配置中心(纯代码实践)
相信大家都知道,每个项目中会有一些配置信息放在一个独立的properties文件中,比如application.properties.这个文件中会放一些常量的配置,比如数据库连接信息.线程池大小.限流 ...
随机推荐
- js解决跨站点脚本编制问题
1.前台处理(容易绕过): <script type="text/javascript"> $(document).ready(function(){ var url= ...
- FreeMarker中的list集合前后台代码
freemarker中的list集合前后台代码: FreeMarker是一款模板引擎: 即一种基于模板和要改变的数据, 并用来生成输出文本(HTML网页.电子邮件.配置文件.源代码等)的通用工具. 它 ...
- Lambda编写斐波那契数列
还需要考虑溢出等问题,闲来无事写了写 Func<float, float, float> a = (arg1, arg2) => 0f;//init ; a = (lastNumbe ...
- vue 和ng的区别
vue: 读音: v-u-e view vue到底是什么? 一个mvvm框架(库).和angular类似 比较容易上手.小巧 mvc: ...
- linux的RMP命令(rmp包的安装与反安装)
RMP 是 LINUX 下的一种软件的可执行程序,你只要安装它就可以了.这种软件安装包通常是一个RPM包(Redhat Linux Packet Manager,就是Redhat的包管理器),后缀是. ...
- 折腾kali linux2.0
偶然的机会了解到了kali linux这个用于渗透测试的linux发行版,于是就从官网下了iso,但是制作启动盘老出错.网上查了下说在linux下用dd命令特别简单,于是转到ubuntu下制作启动盘, ...
- [C++]在什么时候需要“#include string.h“
相关资料:https://zhidao.baidu.com/question/515578726.html C++中,string头文件基本上已经包含在iostream中了.但是,平时使用的时候建议加 ...
- 一款基于jquery超炫的弹出层提示消息
今天给大家带来一款基于jquery超炫的弹出层提示消息.这款实例页面初始时,一个go按钮.当单击go按钮时,提示强出层以动画形式出现.效果图如下: 在线预览 源码下载 实现的代码. html代码: ...
- ptxdist for sama5d3
http://www.vahanus.net/~csc/scm/ptxdist-at91sama5d3-xpld.git/
- oracle查询数据库最大连接数等信息
.当前的数据库连接数 select count(*) from v$process where program='ORACLE.EXE(SHAD)'; .数据库允许的最大连接数 select valu ...