Java-Vector
来源:互联网 发布:单片机控制继电器 编辑:程序博客网 时间:2024/05/17 22:49
对于List接口这里还介绍一个它的实现类Vector,Vector 类可以实现可增长的对象数组。
一、Vector简介
Vector可以实现可增长的对象数组。与数组一样,它包含可以使用整数索引进行访问的组件。不过,Vector的大小是可以增加或者减小的,以便适应创建Vector后进行添加或者删除操作。
Vector实现List接口,继承AbstractList类,所以我们可以将其看做队列,支持相关的添加、删除、修改、遍历等功能。
Vector实现RandmoAccess接口,即提供了随机访问功能,提供提供快速访问功能。在Vector我们可以直接访问元素。
Vector 实现了Cloneable接口,支持clone()方法,可以被克隆。
Vector提供了四个构造函数:
在成员变量方面,Vector提供了elementData , elementCount, capacityIncrement三个成员变量。其中
elementData :"Object[]类型的数组",它保存了Vector中的元素。按照Vector的设计elementData为一个动态数组,可以随着元素的增加而动态的增长,其具体的增加方式后面提到(ensureCapacity方法)。如果在初始化Vector时没有指定容器大小,则使用默认大小为10.
elementCount:Vector
对象中的有效组件数。
capacityIncrement:向量的大小大于其容量时,容量自动增加的量。如果在创建Vector时,指定了capacityIncrement的大小;则,每次当Vector中动态数组容量增加时>,增加的大小都是capacityIncrement。如果容量的增量小于等于零,则每次需要增大容量时,向量的容量将增大一倍。
同时Vector是线程安全的!
二、源码解析
对于源码的解析,LZ在这里只就增加(add)删除(remove)两个方法进行讲解。
2.1增加:add(E e)
add(E e):将指定元素添加到此向量的末尾。
这个方法相对而言比较简单,具体过程就是先确认容器的大小,看是否需要进行扩容操作,然后将E元素添加到此向量的末尾。
对于Vector整个的扩容过程,就是根据capacityIncrement确认扩容大小的,若capacityIncrement <= 0 则扩大一倍,否则扩大至capacityIncrement 。当然这个容量的最大范围为Integer.MAX_VALUE即,2^32 - 1,所以Vector并不是可以无限扩充的。
2.2、remove(Object o)
因为Vector底层是使用数组实现的,所以它的操作都是对数组进行操作,只不过其是可以随着元素的增加而动态的改变容量大小,其实现方法是是使用Arrays.copyOf方法将旧数据拷贝到一个新的大容量数组中。Vector的整个内部实现都比较简单,这里就不在重述了。
三、Vector遍历
Vector支持4种遍历方式。
3.1、随机访问
因为Vector实现了RandmoAccess接口,可以通过下标来进行随机访问。
3.2、迭代器
3.2、for循环
3.4、Enumeration循环
——————————————————————————————————————————————————————————————————————————-- 原文出自:http://cmsblogs.com/?p=1180。尊重作者的成果,转载请注明出处!
-- 个人站点:http://cmsblogs.com
版权声明:本文为博主原创文章,未经博主允许不得转载。
- Java Vector
- java vector
- Java-Vector
- java vector
- java Vector
- Java-Vector
- 【java】【java collection】Vector
- java.util.Vector翻译
- java vector 帮助
- java vector的使用
- vector在JAVA
- java Vector的用法
- Java.Vector.Enumeration
- 关于java Vector类
- JAVA中使用Vector
- 《java中的vector类》
- java中的Vector类
- java Vector and Hashtable
- 帧动画关键帧处加入触发函数
- OpenMesh学习记录 1
- EventBus篇一:ThreadMode
- FLEX通过ANE调用安卓 ExtensionContext.createExtensionContext 返回null
- SSL
- Java-Vector
- 三国演义说明:再牛逼都是扯淡 ,活的岁数最大才是最重要
- listview的简单使用(Baseadapter)
- 已经搬家到新博客 jjyy.guru
- storm是如何保证at least once语义的
- JDK安装与环境变量配置
- CVPR 2014 papers
- android Nine-Patch的使用(制作聊天界面必学)
- C#中param关键字