这几天仔细研究下关于ArrayList容器的jdk源码,感觉收获颇多,以前自己只知道用它,但它里面具体是怎样实现的就完全不清楚了。于是自己尝试模拟写下java的ArrayList容器,简单了实现的ArrayList类中几个方法,当然这仅仅只是加深对容器的理解,因此希望我的分享也能够给大家带来帮助。

一、AyyayList到底是什么?

其实ArrayList就是一个java中的一个类而已,说起来没什么复杂的,好,既然是类,是不是就有成员属性和成员方法。点击查看ArrayList的outline,来看看他有哪些属性和方法。

注意看下我着重标记的那一块,是不是明白了什么。其实ArrayList的底层实现是一个Object数组,也就是elementData数组,它用来存储ArrayList添加的元素,这也就是为什么ArrayList为什么能够存储任何一切对象,因为它本身就是一个object数组。而size属性只是用来保存存储元素的个数,因为是私有的,所以只能通过size方法返回size的值,下面三个就是ArrayList的三个构造方法了。

二、自己简单编码实现ArrayList类

    有了上面的知识铺垫,现在可以开始编写我们自己ArrayList类了。首先创建一个MyArrayList类,因为我现在只是简单的实现ArrayList类,所以在MyArrayList类中就只有两个核心的成员属性,Object【】 elementData ;int size.在定义完属性以后,然后编写构造方法。

public class MyArrayList {
//ArrayList的底层实现是根据数组实现,定义一个存储元素的数组,类型为object,可以存取任意类型的元素
private Object[] elementData;
//表示存储元素的个数
private int size;
//初始化elementData数组空间
public MyArrayList(int initialCapacity){
elementData = new Object[initialCapacity];
}
//重载构造方法,默认存储个数为3;
public MyArrayList(){
this(3);
}
}

这里我实现了两个构造方法,构造方法主要是初始化elementData数组的大小,默认为3个,接下来在继续实现add方法。

public void add(Object o){
//如果容器已满,则进行扩容,扩容为以前的两倍
if(size==elementData.length){
Object[] newArray =new Object[elementData.length*2];
System.arraycopy(elementData,0, newArray, 0,size);
elementData = newArray;
} elementData[size] = o;
size++;
}

这里的话主要是有个需要扩容的地方,我这里默认扩展为原来的两倍,其实扩容的本质就是重新建立一个数组,开辟另外一片空间。相信大家看到这里基本明白了剩下的方法怎么写了,这里我就不细说了,我这里就 附上自己写的PS:我也只是简单的写了下,读者有兴趣可以自己研究,嘿嘿。

/*
* 自己简单的实现ArrayList容器
*/
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List; public class MyArrayList {
//ArrayList的底层实现是根据数组实现,定义一个存储元素的数组,类型为object,可以存取任意类型的元素
private Object[] elementData;
//表示存储元素的个数
private int size;
//初始化elementData数组空间
public MyArrayList(int initialCapacity){
elementData = new Object[initialCapacity];
}
//重载构造方法,默认存储个数为10;
public MyArrayList(){
this(3);
}
//添加元素的方法
public void add(Object o){
//如果容器已满,则进行扩容,扩容为以前的两倍
if(size==elementData.length){
Object[] newArray =new Object[elementData.length*2];
System.arraycopy(elementData,0, newArray, 0,size);
elementData = newArray;
} elementData[size] = o;
size++;
}
//返回元素的个数
public int size(){
return size;
}
//通过索引获取元素的值
public Object get(int i){
if(i<0||i>size-1){
return null;
}
return this.elementData[i];
}
//判断是否为空
public boolean empty(){
return size==0;
}
//把ArrayList转换为数组
public Object[] toArray(){
return Arrays.copyOf(this.elementData,size);
} public static void main(String[] args) { //创建myarraylist的一个容器对象
MyArrayList myarray = new MyArrayList();
//为容器对象添加元素
myarray.add("fsdf");
myarray.add("21343");
myarray.add("21343");
myarray.add("21343");
myarray.add("21343");
myarray.add("21343");
myarray.add("21343");
//遍历输出
for(int i=0;i<myarray.size();i++){
System.out.println(myarray.get(i));
}
System.out.println(myarray.size());
Object[] o1 = myarray.toArray();
for(int i=0;i<o1.length;i++){
System.out.println(o1[i]);
}
}
}

容器_JDK源码分析_自己简单实现ArrayList容器的更多相关文章

  1. JUC源码分析-集合篇:并发类容器介绍

    JUC源码分析-集合篇:并发类容器介绍 同步类容器是 线程安全 的,如 Vector.HashTable 等容器的同步功能都是由 Collections.synchronizedMap 等工厂方法去创 ...

  2. .net core 轻量级容器 ServiceProvider 源码分析

    首先看 ServiceCollection 的定义 //定义 public class ServiceCollection : IServiceCollection { private readonl ...

  3. 深入理解 spring 容器,源码分析加载过程

    Spring框架提供了构建Web应用程序的全功能MVC模块,叫Spring MVC,通过Spring Core+Spring MVC即可搭建一套稳定的Java Web项目.本文通过Spring MVC ...

  4. Java容器 | 基于源码分析List集合体系

    一.容器之List集合 List集合体系应该是日常开发中最常用的API,而且通常是作为面试压轴问题(JVM.集合.并发),集合这块代码的整体设计也是融合很多编程思想,对于程序员来说具有很高的参考和借鉴 ...

  5. java集合源码分析(三):ArrayList

    概述 在前文:java集合源码分析(二):List与AbstractList 和 java集合源码分析(一):Collection 与 AbstractCollection 中,我们大致了解了从 Co ...

  6. spring5源码分析系列(三)——IOC容器的初始化(一)

    前言: IOC容器的初始化包括BeanDefinition的Resource定位.载入.注册三个基本过程. 本文以ApplicationContext为例讲解,XmlWebApplicationCon ...

  7. Java容器 | 基于源码分析Map集合体系

    一.容器之Map集合 集合体系的源码中,Map中的HashMap的设计堪称最经典,涉及数据结构.编程思想.哈希计算等等,在日常开发中对于一些源码的思想进行参考借鉴还是很有必要的. 基础:元素增查删.容 ...

  8. Java 容器 LinkedHashMap源码分析1

    同 HashMap 一样,LinkedHashMap 也是对 Map 接口的一种基于链表和哈希表的实现.实际上, LinkedHashMap 是 HashMap 的子类,其扩展了 HashMap 增加 ...

  9. jQuery源码分析_工具方法(学习笔记)

    expando:生成唯一JQ字符串(内部使用) noConflict():防止冲突 isReady:DOM是否加载完成(内部) readyWait:等待多少文件的计数器(内部) holdReady() ...

随机推荐

  1. 关于微信小程序的的总结

    微信小程序学完了,给大家分享一些自己学小程序的心得,希望能帮到大家. 首先,我谈谈小程序数据绑定的那一块,所有从本地或者远程服务器的API传过来,都必须绑定到data: {}, 绑定格式是一个一个的键 ...

  2. 【Netty】WebSocket

    一.前言 前面学习了codec和ChannelHandler之间的关系,接着学习WebSocket. 二.WebSocket 2.1. WebSocket介绍 WebSocket协议允许客户端和服务器 ...

  3. js—浅谈方法和思路的重要性(首篇求大佬支持)

    js-浅谈方法和思路的重要性 学了这么久的js,我从老师的,同学的代码中发现,老师写的代码比我们的要清楚的很多,基本上没有太多累赘啊,能少的没有少啊等等..... 废话不多说,下面我们来看看这个我的一 ...

  4. nfs+rsync+inotify实现文件的实时同步

    准备三台服务器进行测试: nfs_server:192.168.12.110 web_server:192.168.12.111 rsync_server:192.168.12.112 网络规划图: ...

  5. PHP实现Collection数据集类及其原理

    本文目录 : Collection源码 讲解与例子 ArrayAccess的使用 JsonSerializable的使用 Countable的使用 IteratorAggregate.ArrayIte ...

  6. hdu3715

    hdu3715 题意 给出一个递归的伪代码,当 x[a[dep]] + x[b[dep]] != c[dep],就向下递归,给出a,b,c数组的值 问 dep 最大多少.其中 0 <= c[i] ...

  7. 【毕业设计】基于Android的家校互动平台开发(内含完整代码和所有文档)——爱吖校推(你关注的,我们才推)

    ☆ 写在前面 之前答应大家的毕业答辩之后把所有文档贡献出来,现在答辩已过,LZ信守承诺,把所有文档开源到了GitHub(这个地址包含所有的代码和文档以及PPT,外层为简单的代码).还望喜欢的朋友们,不 ...

  8. oracle日期时间函数 总结

    表中存在伪列:sysdate,systimestamp 伪列存在但是不显示 select sysdate from dual; select systimestamp from dual; 日期计算公 ...

  9. 什么是Css Hack?ie6,7,8的hack分别是什么?

    针对不同的浏览器写不同的CSS code的过程,就是CSS hack. 示例如下: 1 2 3 4 5 6 7 8 9 10 11 12 #test       { width:300px; heig ...

  10. 关于java反射获取泛型

    public class Test<T> { private final TypeToken<T> typeToken = new TypeToken<T>(get ...