从零开始学Java系列教程(一):数据结构(Vector类)

Vector类

Vector类是List接口的实现类,而List接口是Collection的子接口,因此Vector类可以使用List接口和Collection接口的所有方法。

Vector类和ArrayList类的用法几乎一模一样,底层都是采用了数组结构,很多情况下可以互用。只不过Vector类的方法都加了同步检查,因此“线程安全,效率低”。 

比如:add(E e)方法就增加了synchronized同步标记。

 

相比较于ArrayList,Vector还包含了许多传统的方法,虽然这些方法不属于集合框架。

Vector类演示:

public class Test {
	public static void main(String[] args) {
		// 实例化一个Vector
		Vector<String> vector = new Vector<String>();
		// 添加元素,addElement()方法和add()方法类似
		vector.addElement("java");
		vector.addElement("HTML");
		vector.addElement("JavaScript");
		vector.addElement("CSS");
		// 遍历集合, elements()方法类似于iterator()方法
		Enumeration<String> elements = vector.elements();
		while(elements.hasMoreElements()) {
			System.out.println(elements.nextElement());
		}
	}
}

【新手建议】如何选用ArrayList、LinkedList、Vector?

需要保证线程安全时,建议选用Vector。

不存在线程安全问题时,并且查找较多用ArrayList(一般使用它)。

不存在线程安全问题时,增加或删除元素较多用LinkedList。

注意:现实开发中,我们常用ArrayList集合,很少使用Vector集合。


Vector类的传统方法:

public synchronized void addElement(E obj)          --> 此方法的作用和add(E element)类似

public Enumeration<E> elements()                         --> 此方法的作用和iterator()类似

boolean hasMoreElements();                                  --> 此方法的作用和hasNext()类似

E nextElement();                                                      --> 此方法的作用和next()类似

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值