最近就是想扒一扒存在硬盘里面的学习资料(突然想到什么),把以前写过的一些东西整理一下分享出来。

这边是ArrayList 的简单实现,当然只实现了部分方法

package com.yck.collection;

import java.util.Iterator;

/**
 * 手动实现ArrayList的主要功能
 * ArrayList的底层实现就是数组
 *
 */

public class MyArrayList
{
    private Object []elementDate;    //
    private int size;

    /**
     * 索引范围的检查
     * @param index
     */
    private void rangCheck(int index)
    {
        if(index<0 || index >= size)
        {
            try
            {
                throw new Exception();
            }
            catch (Exception e)
            {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
    }

    /**
     * 带参构造
     * @param initicalCapacity
     */
    public MyArrayList(int initicalCapacity)
    {
        if(initicalCapacity<0)
            try
        {
            throw new Exception("int cannot below 0.");
        }
        catch (Exception e)
        {
                // TODO Auto-generated catch block
                e.printStackTrace();
        }
        this.elementDate = new Object[initicalCapacity];
    }

    /**
     * 无参构造,使用上一个构造函数,初始化数组长度默认为10
     */
    public MyArrayList()
    {
        this(10);
    }

    /**
     * 以下是List接口的一些方法实现,主要的问题在于add 和 remove一定要记住size要跟着改变
     * 方法的实现很简单,看一下就能懂
     * @param obj
     */
    public void add(Object obj)
    {
        if(size >= elementDate.length)
        {
            Object []newElementDate = new Object[size*2];
            /**
             * 用for循环写一个复制方法。
             */
            for(int i=0;i<elementDate.length;i++)
            {
                newElementDate[i] =elementDate[i];
            }
            elementDate = newElementDate;
        }
        elementDate[size] = obj;
        size++;
    }

    public void add(MyArrayList arr)
    {
        if((size+arr.elementDate.length)>this.elementDate.length)//是否需要扩容判断
        {
            Object []newElementDate = new Object[(size+arr.elementDate.length)*2];
            //System.arraycopy(elementDate, 0, newElementDate, 0, elementDate.length);//调用系统方法复制
            for(int i=0;i<this.size;i++)
            {
                newElementDate[i] = elementDate[i];
            }
            elementDate = newElementDate;
        }
        for(int i=0;i<arr.size;i++)
        {
            this.elementDate[size]=arr.elementDate[i];
            size++;
        }

    }

    public void remove(int index)
    {
        this.rangCheck(index);
        for(int i=index;i<elementDate.length-1;i++)
            elementDate[i] = elementDate[i+1];
        size--;

    }
    public void remove(Object obj)
    {
        for(int i=0;i<size;i++)
        {
            if(this.get(i).equals(obj))
                this.remove(i);
        }
    }

    public Object get(int index)
    {
        this.rangCheck(index);
        return this.elementDate[index];

    }

    public int size()
    {
        return this.size;
    }
    public boolean isEmpty()
    {
        if(this.size == 0)
            return true;
        else return false;
    }

    public Iterator iterator()
    {
        return new MyIt();
    }

    private class MyIt implements Iterator //那个什么跌蛋器。。不好意思我输入法写出来是这样。。。自定义迭代器的实现
    {
        private int cursor = -1;  //游标初始值置为-1;

        /**
         * 判断是否有下一个元素
         * 1、如果curror + 1 < size;说明有,返回true
         * 2、如果curror + 1 >size;说明没有,返回 false
         */
        public boolean hasNext()
        {
            return cursor+1 < size;
        }

        /**
         * 取出下当前元素,并把游标指向下一个元素
         */
        public Object next()
        {
            cursor++;
            return elementDate[cursor];
        }
    }

    public static void main(String[] args)
    {
        MyArrayList list = new MyArrayList(3);
        list.add("aaa");
        list.add("uuu");
        list.add("ddd");
        list.add("eee");
        System.out.println(list.elementDate.length+"..."+list.size);
        for(Iterator iter = list.iterator();iter.hasNext();)
        {
            System.out.println((String)iter.next());
        }
    }

}

上面有简单的测试,主要是为了测试迭代器。当时写的时候肯定是写一个方法测试一下的= =

有兴趣的朋友可以稍作修改加上泛型

javaSE基础之 ArrayList的底层简单实现的更多相关文章

  1. javaSE基础之 LinkedList的底层简单实现

    这里贴上LinkedList底层的简单实现 package com.yck.mylinkedlist; public class Node { private Node previous; //上一结 ...

  2. 基础1 JavaSe基础

    JavaSe基础 1. 九种基本数据类型的大小,以及他们的封装类 boolean 无明确指定 Boolean char 16bits Character byte 8bits Byte short 1 ...

  3. Java基础系列-ArrayList

    原创文章,转载请标注出处:<Java基础系列-ArrayList> 一.概述 ArrayList底层使用的是数组.是List的可变数组实现,这里的可变是针对List而言,而不是底层数组. ...

  4. Java基础系列--ArrayList集合

    原创作品,可以转载,但是请标注出处地址:http://www.cnblogs.com/V1haoge/p/8494618.html 一.概述 ArrayList是Java集合体系中最常使用,也是最简单 ...

  5. java学习之路之javaSE基础1

    <h2>java学习之路之javaSE基础1</h2> <div> ###01.01_计算机基础知识(计算机概述)(了解)* A:什么是计算机?计算机在生活中的应用 ...

  6. JavaSE基础:集合类

    JavaSE基础:集合类 简单认识类集 我们学习的是面向对象语言,而面向对象语言对事物的描述是通过对象体现的,为了方便对多个对象进行操作,我们就必须把这多个对象进行存储. 而要向存储多个对象,就不能是 ...

  7. javaSE基础07

    javaSE基础07 一.static静态修饰符 用了static修饰的变量就会变成共享的属性,只会初始化一次,在内存中只存在一个,并且每个对象都可以访问,存放在方法区(数据共享区) 1.1 stat ...

  8. javaSE基础06

    javaSE基础06 一.匿名对象 没有名字的对象,叫做匿名对象. 1.2匿名对象的使用注意点: 1.我们一般不会用匿名对象给属性赋值的,无法获取属性值(现阶段只能设置和拿到一个属性值.只能调用一次方 ...

  9. javaSE基础04

    javaSE基础04 一.三木运算符 <表达式1> ? <表达式2> : <表达式3> "?"运算符的含义是: 先求表达式1的值, 如果为真, ...

随机推荐

  1. DL4NLP——词表示模型(二)基于神经网络的模型:NPLM;word2vec(CBOW/Skip-gram)

    本文简述了以下内容: 神经概率语言模型NPLM,训练语言模型并同时得到词表示 word2vec:CBOW / Skip-gram,直接以得到词表示为目标的模型 (一)原始CBOW(Continuous ...

  2. log4j(一)——为什么要用log4j?

    一:试验环境 OS:win7 JDK:jdk7 Log4j:1.2.17(好尴尬,原本是想试验下log4j2的,结果阴差阳错用了这个版本,不过幸好,试验也不白试验,试验的作用是一样的) 二:先看两个简 ...

  3. (转)JAVA排序汇总

    JAVA排序汇总 package com.softeem.jbs.lesson4; import java.util.Random; /** * 排序测试类 * * 排序算法的分类如下: * 1.插入 ...

  4. Python零基础学习系列之一--初识计算机!

    1-1.计算机概念: Computer: 原指专门负责计算的人,后来演变成特指计算设备,译为"计算机" 计算机的概念: 计算机是能够根据一组指令操作数据的机器. A compute ...

  5. H5入门——HTML部分

    一.HTML的基本构成 1.<!DOCTYPE html>文档类型声明 <!--HTML的文档类型声明.声明这个文件是HTML5文件,让浏览器按照HTML5准备进行解析显示.文档类型 ...

  6. 带你快速进入.net core的世界

    [申明]:本人.NET Core小白.Linux小白.MySql小白.nginx小白.而今天要说是让你精通Linux ... 的开机与关机.nginx安装与部署.Core的Hello World .. ...

  7. java中什么样的对象能够进入老年代

    1.大对象:所谓的大对象是指需要大量连续内存空间的java对象,最典型的大对象就是那种很长的字符串以及数组,大对象对虚拟机的内存分配就是坏消息,尤其是一些朝生夕灭的短命大对象,写程序时应避免. 2.长 ...

  8. 自定义Git之配置别名

    有没有经常敲错命令?比如git status?status这个单词真心不好记. 如果敲git st就表示git status那就简单多了,当然这种偷懒的办法我们是极力赞成的. 我们只需要敲一行命令,告 ...

  9. 8. Andrénalin ★ Serial

    无花无壳爆破/硬编码 istcmp字符串比较 "<BrD-SoB>" 仅允许非商业转载,转载请注明出处

  10. 【HTTP权威指南】第二章-URL与资源

    [统一资源定位符URL]通过位置来标示资源,其表达的格式如下:https://item.jd.com/523961.html 第一部分(https)是方案,告知客户端要[怎样访问],这里使用的是htt ...