arraylist是list接口的一个可变长数组实现。实现了所有list接口的操作,并允许存储null值。除了没有进行同步,arraylist基本等同于vector。在vector中几乎对所有的方法都进行了同步,但arraylist仅对writeobject和readobject进行了同步,其它比如add(object)、remove(int)等都没有同步。
1.存储
arraylist使用一个object的数组存储元素。
| private transient object elementdata[]; |
| public boolean add(object o) { ensurecapacity(size + 1); // increments modcount!! elementdata[size++] = o; return true; } |
| public object remove(int index) { rangecheck(index); modcount++; object oldvalue = elementdata[index]; int nummoved = size - index - 1; if (nummoved > 0) system.arraycopy(elementdata, index+1, elementdata, index, nummoved); elementdata[--size] = null; // let gc do its work return oldvalue; } |
| arraylist list = new arraylist(); |
| public arraylist() { this(10); } |
| public boolean add(object o) public void add(int index, object element) public boolean addall(collection c) public boolean addall(int index, collection c) |
| public void ensurecapacity(int mincapacity) { modcount++; int oldcapacity = elementdata.length; if (mincapacity > oldcapacity) { object olddata[] = elementdata; int newcapacity = (oldcapacity * 3)/2 + 1; if (newcapacity < mincapacity) newcapacity = mincapacity; elementdata = new object[newcapacity]; system.arraycopy(olddata, 0, elementdata, 0, size); } } |
| public boolean add(object o) { ensurecapacity(size + 1); // increments modcount!! elementdata[size++] = o; return true; } |
Java Asp PHP .Net XML C/C++ CGI VB Jsp J2ee J2se J2me EJB Servlet Tomcat Resin Struts Weblogic Eclipse ANT GUI JMS Web servise IDEA Webphere Hibernate Spring Jboss Applet Swing Socket Javamail Perl Ajax P2P 安全 模式 框架 测试 开源 游戏
Windows XP Windows 2000 Windows 2003 Windows Me Windows 9.x Linux UNIX 注册表 操作系统 服务器 应用服务器