Java中SJBArrayList自己简单实现ArrayList
/**
* 自己实现ArrayList
* @author zyyt
*
*/
public class SJBArrayList {
//存放SJBArrayList中的元素
transient Object[] elementData;
//SJBArrayList中含有多少个元素
private int size;
//构造方法
public SJBArrayList(){
this(10);
}
public SJBArrayList(int initialCapacity)
{ //对elementData进行初始化
if (initialCapacity > 0) {
this.elementData = new Object[initialCapacity];
} else if (initialCapacity == 0) {
this.elementData = new Object[0];
} else {
throw new IllegalArgumentException("Illegal Capacity: "+
initialCapacity);
}
}
//判断这个SJBArrayList是否包含元素,如果不包含元素返回true 如果包含则返回false
public boolean isEmpty(){
return size == 0;
}
//返回这个SJBArrayList中包含的元素的个数
public int size(){
return size;
}
//添加一个元素
public void add(Object obj)
{
if(size == elementData.length){
Object[] array = new Object[size * 2 +1];
System.arraycopy(elementData, 0, array, 0, elementData.length);
elementData = array;
}
elementData[size++] = obj;
}
//获取对应索引中的元素
public Object get(int index){
if(index<0 || index >= size){
System.out.println("index超过最大索引值或者index小于0");
return null;
}
return elementData[index];
}
//删除对应索引的值
public Object remove(int index){
if(index < 0 || index > size){
System.out.println("index小于0,或者越界");
System.exit(0);
}
Object oldValue = this.get(index);
System.arraycopy(elementData, index + 1,elementData, index, size);
elementData[size--] = null;
return oldValue;
}
//提货对应索引中的值
public Object set(int index,Object obj)
{
if(index < 0 || index > size){
System.out.println("index小于0,或者越界");
System.exit(0);
}
Object oldValue = this.get(index);
elementData[index] = obj;
return oldValue;
}
//清空SJBArrayList
public void clear(){
for(int i=0;i<size;i++){
elementData[i] = null;
}
size = 0;
}
public static void main(String[] args){
SJBArrayList sjbList = new SJBArrayList();
sjbList.add("111");
sjbList.add("2222");
sjbList.add("3333");
sjbList.add("4444");
sjbList.add("5555");
sjbList.add("66666");
sjbList.remove(2);
System.out.println(sjbList.get(3));
for(int i=0;i<sjbList.size();i++){
System.out.println(sjbList.get(i));
}
}
}
Java中SJBArrayList自己简单实现ArrayList的更多相关文章
- java中把list列表转为arrayList以及arraylist数组截取的简单方法
java中把list列表转为arrayList以及arraylist数组截取的简单方法 package xiaobai; import java.util.ArrayList; import java ...
- 在Java中怎样把数组转换为ArrayList?
翻译自:How to Convert Array to ArrayList in Java? 本文分析了Stack Overflow上最热门的的一个问题的答案,提问者获得了很多声望点,使得他得到了在S ...
- 多线程(三) java中线程的简单使用
java中,启动线程通常是通过Thread或其子类通过调用start()方法启动. 常见使用线程有两种:实现Runnable接口和继承Thread.而继承Thread亦或使用TimerTask其底层依 ...
- java中数据流的简单介绍
java中的I/O操作主要是基于数据流进行操作的,数据流表示了字符或者字节的流动序列. java.io是数据流操作的主要软件包 java.nio是对块传输进行的支持 数据流基本概念 “流是磁盘或其它外 ...
- Java中常见数据结构List之ArrayList
这里主要包含ArrayList和LinkedList, 然后再添加一个:CopyOnWriteArrayList 关于Java中的集合内容, 感觉都已经被写烂了, 我这里主要是做个复习, 再从扒下源代 ...
- java中volatile的简单理解
原创作品,可以转载,但是请标注出处地址:http://www.cnblogs.com/V1haoge/p/7833881.html 据说,volatile是java语言中最轻量级的并发控制方式. vo ...
- 关于JAVA中异常处理的简单阐释.
---恢复内容开始--- 这是我的一篇要在博客园发布的随笔,主要是简单的概括一下我本次所学的关于异常处理的知识.有讲的不妥当的地方,或者有需要补充的,还请各位高人给指点,共同学习,虚心求学.谢谢啦~ ...
- Java中的集合List、ArrayList、Vector、Stack(三)
List接口 List集合代表一个有序集合,集合中每一个元素都有其对应的顺序索引.List集合容许使用重复元素,可以通过索引来访问指定位置的集合对象. ArrayList和Vector实现类 Arra ...
- redis学习笔记(二)——java中jedis的简单使用
redis怎么在java中使用,那就是要用到jedis了,jedis是redis的java版本的客户端实现,原本原本想上来就直接学spring整合redis的,但是一口吃个胖子,还是脚踏实地,从基础开 ...
随机推荐
- [HMLY]10.iOS中block的基础用法
本文简介 本章不会对Block做过多的实现研究.只是讲解基本的用法.纯粹基础知识.结合实际项目怎么去做举例.Block使用场景,可以在两个界面的传值,也可以对代码封装作为参数的传递等.用过GCD就知道 ...
- flexbox备忘
伸缩项目的父元素: display:flex || display:inline-flex fiex-direction: row(默认) | row-reverse | column | colum ...
- Lamada转化字符类型
//SN为字符串类型,将其转换成Int等数字类型 ---第一种 List<Testing_Report_Enclosureslist> enclosuresList = _db.Testi ...
- typings 命令使用注意
1.如果要查询一些库 typings search xxx 2.安装jquery node 这样的库要这样 typings dt~node --global --save 一定要dt~xxx ,然 ...
- ios_swift开发资源整理
目录 1.苹果官方资源 2.国内外视频网站推荐 3.中文文档 4.demo网站 5.开发工具推荐 6.国内外开发网站论坛 7.技术博客推荐 8.书籍推荐 9.第三方框架推荐 10.第三方发布平台 11 ...
- 获取URL中的参数值
//获取url中ID的值function getParamByName(name, url) { var match = RegExp('[?&]' + name + '=([^&]* ...
- Lua 数据类型和 Redis 数据类型之间转换
当 Lua 通过 call() 或 pcall() 函数执行 Redis 命令的时候,命令的返回值会被转换成 Lua 数据结构. 同样地,当 Lua 脚本在 Redis 内置的解释器里运行时,Lua ...
- Homestead PHP7安装phpredis扩展
sudo mkdir /home/phpredis/ && cd /home/phpredis/ sudo git clone -b php7 https://github.com/p ...
- js框架封装,模拟jQuery封装
模拟jQuery框架,利用原生的js技术,封装一个js框架,以加深对jQuery的常用api的使用和面向对象原理的理解:一:结构部分首先利用闭包,构造一个自执行函数,然后利用选择器函数Sizzle,获 ...
- 数据库索引的实现原理(笔记)详细http://www.linezing.com/blog/?p=798#nav-1
数据库索引,是数据库管理系统中一个排序的数据结构,以协助快速查询.更新数据库表中数据.索引的实现通常使用B树及其变种B+树. 在数据之外,数据库系统还维护着满足特定查找算法的数据结构,这些数据结构以某 ...