`
greemranqq
  • 浏览: 966988 次
  • 性别: Icon_minigender_1
  • 来自: 重庆
社区版块
存档分类
最新评论

JAVA深入集合--Vector

阅读更多

一.介绍

Vector 本质是一个数组,当然他具有数组的通过下标访问等特性,同时这玩意儿继承了 AbstractList 。当然他具有了集合的通用功能,同时他实现了 List,RandomAccess,Cloneable ,Sertializable 接口。

这里大概提一下RandomAccess 和 Cloneable 

1.1 RandomAccess 可以让其拥有随机访问的能力,可以用迭代器进行迭代,某些情况 下 会有更好性能。没有就无法使用Iterator迭代器。

 

1.2 Cloneable 会提供Object clone 功能,没有就无法clone

 

 

 

 

关于这里的研究我们以后再谈,还是先来说Vector 。

 

 

二.代码分析

 

2.1 Vector 的属性 :
     protected Object[] elementData; 这是用来存放元素的。
     protected int elementCount; 这是记录这个对象存放了好多个元素
     protected int capacityIncrement; 这是增长因子,就是你数组放不下了,增加容量。

2.2 构造方法:
     public Vector() {
	  this(10);
  }
  
    public Vector(int initialCapacity, int capacityIncrement) {
	     this.elementData = new Object[initialCapacity];
	     this.capacityIncrement = capacityIncrement;
   }
  
     public Vector(int initialCapacity) {
	    this(initialCapacity, 0);
   }
  
     这里我取了主要部分,从构造不难看出,我们默认 new Vector(),实际上是通过public Vector(int initialCapacity, int capacityIncrement) 方法,创建了长度为10 ,增长因子为0 的Object 数组。这里如果大概知道数组长度,请指定长度,必然复制数组带来的开销。



public Vector(Collection<? extends E> c) {
	elementData = c.toArray();
	elementCount = elementData.length;
	// c.toArray might (incorrectly) not return Object[] (see 6260652)
	if (elementData.getClass() != Object[].class)
	    elementData = Arrays.copyOf(elementData, elementCount, Object[].class);
    }

这个构造 是把集合元素存放到Vector对象里面。

 

3.3 方法介绍:这里只介绍几个主要的,其余可以查询API


public synchronized boolean add(E e) {
	modCount++;
	ensureCapacityHelper(elementCount + 1);
	elementData[elementCount++] = e;
        return true;
  }
  
 private void ensureCapacityHelper(int minCapacity) {
	int oldCapacity = elementData.length;
	if (minCapacity > oldCapacity) {
	    Object[] oldData = elementData;
	    int newCapacity = (capacityIncrement > 0) ?
		(oldCapacity + capacityIncrement) : (oldCapacity * 2);
    	    if (newCapacity < minCapacity) {
		newCapacity = minCapacity;
	    }
            elementData = Arrays.copyOf(elementData, newCapacity);
	}
    }

 方法:add(E e)

      就是添加一个元素,这里通过ensureCapacityHelper 方法进行判断添加的个数,从ensureCapacityHelper(elementCount + 1);知道,默认是添加一个,这里添加的个数如果超出了原来数组的长度,就用Arrays.copyOf 进行扩容,底层用的System.arraycopy 方法,默认元素加载末尾。关于 modCount 字段是集合用来快速判断迭代过程中失败的标志,也就是说 如果集合在地带过程中,进行了删除等操作 就会报错。

 

同理:
  方法:add(int index,E element) 向指定位置添加元素,实际上访问的是:
   
public synchronized void insertElementAt(E obj, int index) {
	modCount++;
	if (index > elementCount) {
	    throw new ArrayIndexOutOfBoundsException(index
						     + " > " + elementCount);
	}
	ensureCapacityHelper(elementCount + 1);
	System.arraycopy(elementData, index, elementData, index + 1, elementCount - index);
	elementData[index] = obj;
	elementCount++;
      }
但是你发现 最终都是 调用 ensureCapacityHelper 等方法。

还有: public synchronized void addElement(E obj) 方法,和add方法相比,只是返回值不一样,一个是boolean,一个是 void 内部完全一样。


方法: public boolean contains(Object o) 判断元素是否存在,实际访问的是:
 public synchronized int indexOf(Object o, int index) {
	if (o == null) {
	    for (int i = index ; i < elementCount ; i++)
		if (elementData[i]==null)
		    return i;
	} else {
	    for (int i = index ; i < elementCount ; i++)
		if (o.equals(elementData[i]))
		    return i;
	}
	return -1;
  }
  
  简单来说就是一个素组的循环。

 

 

方法:public Enumeration<E> elements()
这里是创建了一个枚举类型,里面实现还是通过元素是否存在,通过下标遍历数组

public Enumeration<E> elements() {
	return new Enumeration<E>() {
	    int count = 0;

	    public boolean hasMoreElements() {
		return count < elementCount;
	    }

	    public E nextElement() {
		synchronized (Vector.this) {
		    if (count < elementCount) {
			return (E)elementData[count++];
		    }
		}
		throw new NoSuchElementException("Vector Enumeration");
	    }
	};
      }
  
  
  当然还有其他方法,就不多做介绍了,就是数组元素的操作而已。

 

小结:

1.Vector 本质是一个数组,其实所有集合都是数组,从JAVA 来说搞成了对象,符合我  们的OO,可以参考学习。

2.Vector 源码看出很多方法都是synchronized 的,线程安全,但是效率就不得不  损耗点了,多线程开发可以使用。

允许的情况,我们可以参考这种模式,设计自己的vector 类,或者其他类,以便于更适应我们的项目。不要把这些看得很圣神,其实都是你和JDK开发人员,差距没那么大,相信自己。

0
0
分享到:
评论

相关推荐

    (超赞)JAVA精华之--深入JAVA API

    1.1 深入JAVA API 1.1.1 Lang包 1.1.2 集合类 1.1.2.1.1 日期类Date 1.1.2.1.2 日历类Calendar 1.1.2.1.3 随机数类Random 1.1.2.1.4 向量类Vector 1.1.2.1.5 栈类Stack 1.1.2.1.6 哈希表类Hashtable 1.1.2.1.7 ...

    程序员需要经常刷题吗-simple-java-zh-CN:SimpleJava是Java常见问题的集合。中文翻译

    需要程序员经常刷题吗simple-java-zh-CN Simple Java 是 Java 常见问题的集合。中文翻译 ##1。 字符串和数组字符串...深入理解Arrays.sort(T[], Comparator &lt; ? super T &gt; c) 常见排序,Collections、Arrays、Tre

    【Java面试+Java学习指南】 一份涵盖大部分Java程序员所需要掌握的核心知识

    Java集合详解1:一文读懂ArrayList,Vector与Stack使用方法和实现原理 Java集合详解2:Queue和LinkedList Java集合详解3:Iterator,fail-fast机制与比较器 Java集合详解4:HashMap和HashTable Java集合详解5:深入...

    2018秋招java笔试题-javapass:java深入学习资料集锦

    集合框架 Java 多线程 Java 虚拟机 jvm Java IO 与 NIO 设计模式 :open_file_folder: 数据结构与算法 数据结构 算法 :laptop: 计算机网络与数据通信 网络相关 数据通信(RESTful,RPC,消息队列)总结 :mobile_phone: ...

    Java工程师面试复习指南

    Java集合详解:一文读懂ArrayList,Vector与Stack使用方法和实现原理 Java集合详解:Queue和LinkedList Java集合详解:迭代器,快速失败机制与比较器 Java集合详解:HashMap和HashTable Java集合详解:深入理解...

    高级java笔试题-interview:采访记录

    高级java笔试题 interview 2017届春招秋招公司的面试题目 #阿里内推(Android开发) ##笔试 ####选择题: 快速排序 二叉树遍历 UML类图 ...7.java集合类,哪些线程安全,哪些线程不安全 8.线程安全

    JAVA_Thinking in Java(中文版 由yyc,spirit整理).chm

    JAVA_Thinking in Java(中文版 由yyc,spirit整理).chm ------------------------------------------------- 本教程由yyc,spirit整理 ------------------------------------------------- “Thinking in Java...

    JAVA SE学习精华集锦

    1.1 深入JAVA API 2 1.1.1 Lang包 2 1.1.2 集合类 8 1.1.2.1.1 日期类Date 9 1.1.2.1.2 日历类Calendar 10 1.1.2.1.3 随机数类Random 11 1.1.2.1.4 向量类Vector 12 1.1.2.1.5 栈类Stack 13 1.1.2.1.6 哈希表类...

    java 编程入门思考

    7.2 深入理解 7.2.1 方法调用的绑定 7.2.2 产生正确的行为 7.2.3 扩展性 7.3 覆盖与过载 7.4 抽象类和方法 7.5 接口 7.5.1 Java的“多重继承” 7.5.2 通过继承扩展接口 7.5.3 常数分组 7.5.4 初始化接口中的字段 7.6...

    Java初学者入门教学

    7.2 深入理解 7.2.1 方法调用的绑定 7.2.2 产生正确的行为 7.2.3 扩展性 7.3 覆盖与过载 7.4 抽象类和方法 7.5 接口 7.5.1 Java的“多重继承” 7.5.2 通过继承扩展接口 7.5.3 常数分组 7.5.4 初始化接口中的字段 7.6...

    java面试笔试资料包括JAVA基础核心知识点深度学习Spring面试题等资料合集.zip

    第四题 ArrayList LinkedList Vector的区别.pdf docker讲得最清楚.doc Dubbo是什么?能做什么?.doc java 基于TCP协议的Socket编程和通信.doc Java面试高级篇—说说TCP,UDP和socket,Http之间联系和区别.doc MySQL...

    java联想(中文)

    7.2 深入理解 7.2.1 方法调用的绑定 7.2.2 产生正确的行为 7.2.3 扩展性 7.3 覆盖与过载 7.4 抽象类和方法 7.5 接口 7.5.1 Java的“多重继承” 7.5.2 通过继承扩展接口 7.5.3 常数分组 7.5.4 初始化接口中的字段 7.6...

    疯狂JAVA讲义

    7.1 Java集合概述 241 7.2 Collection和Iterator接口 243 7.2.1 使用Iterator接口遍历集合元素 244 7.2.2 使用foreach循环遍历集合元素 246 7.3 Set接口 247 7.3.1 HashSet类 247 学生提问:hashCode方法对于...

    JAVA_Thinking in Java

    7.2 深入理解 7.2.1 方法调用的绑定 7.2.2 产生正确的行为 7.2.3 扩展性 7.3 覆盖与过载 7.4 抽象类和方法 7.5 接口 7.5.1 Java的“多重继承” 7.5.2 通过继承扩展接口 7.5.3 常数分组 7.5.4 初始化接口中的字段 7.6...

    Thinking in Java(中文版 由yyc,spirit整理).chm

    7.2 深入理解 7.2.1 方法调用的绑定 7.2.2 产生正确的行为 7.2.3 扩展性 7.3 覆盖与过载 7.4 抽象类和方法 7.5 接口 7.5.1 Java的“多重继承” 7.5.2 通过继承扩展接口 7.5.3 常数分组 7.5.4 初始化接口中的字段 7.6...

    Thinking in Java简体中文(全)

    7.2 深入理解 7.2.1 方法调用的绑定 7.2.2 产生正确的行为 7.2.3 扩展性 7.3 覆盖与过载 7.4 抽象类和方法 7.5 接口 7.5.1 Java的“多重继承” 7.5.2 通过继承扩展接口 7.5.3 常数分组 7.5.4 初始化接口中的字段 7.6...

    Thinking in Java 中文第四版+习题答案

    12.2.7 用Vector进行深层复制 12.2.8 通过序列化进行深层复制 12.2.9 使克隆具有更大的深度 12.2.10 为什么有这个奇怪的设计 12.3 克隆的控制 12.3.1 副本构建器 12.4 只读类 12.4.1 创建只读类 12.4.2 “一成不变”...

    Think in Java(中文版)chm格式

    7.2 深入理解 7.2.1 方法调用的绑定 7.2.2 产生正确的行为 7.2.3 扩展性 7.3 覆盖与过载 7.4 抽象类和方法 7.5 接口 7.5.1 Java的“多重继承” 7.5.2 通过继承扩展接口 7.5.3 常数分组 7.5.4 初始化接口中...

    Java-Interview:此项目为 Java 面试的汇总,多数是一些 Java 基础知识、底层原理、算法详解。也有上层应用设计,其中不乏一些大厂面试真题

    常用集合 ArrayList/Vector LinkedList HashMap HashSet LinkedHashMap Java 多线程 多线程中的常见问题 synchronize 关键字原理 多线程的三大核心 对锁的一些认知 ReentrantLock 实现原理 ConcurrentHashMap 的...

Global site tag (gtag.js) - Google Analytics