前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Vector底层结构和源码分析

Vector底层结构和源码分析

原创
作者头像
兮动人
发布2023-01-23 11:41:47
2350
发布2023-01-23 11:41:47
举报
文章被收录于专栏:兮动人的博客兮动人的博客

1. Vector 的基本介绍

1) Vector类的定义说明

在这里插入图片描述
在这里插入图片描述

2) Vector底层也是一个对象数组, protected Object[] elementData;

在这里插入图片描述
在这里插入图片描述

3) Vector是线程同步的,即线程安全,Vector类的操作方法带有synchronized

代码语言:java
复制
public synchronized E get(int index) {
	if (index > = elementCount)
	throw new ArrayIndexOutOfBoundsException(index);
	return elementData(index);
}	
  • 在开发中,需要线程同步安全时,考虑使用Vector
  • 案例:

2. 源码分析

  1. new Vector() 底层public Vector() { this(10); }补充:如果是 Vector vector = new Vector(8); 走的方法:
代码语言:java
复制
public Vector(int initialCapacity) {
this(initialCapacity, 0);
}
  1. vector.add(i)

2.1 下面这个方法就添加数据到 vector 集合

代码语言:java
复制
public synchronized boolean add(E e) {
modCount++;
ensureCapacityHelper(elementCount + 1);
elementData[elementCount++] = e;
return true;
}

2.2 确定是否需要扩容 条件 : minCapacity - elementData.length>0

代码语言:java
复制
private void ensureCapacityHelper(int minCapacity) {
// overflow-conscious code
if (minCapacity - elementData.length > 0
	grow(minCapacity);
}

2.3 如果 需要的数组大小 不够用,就扩容 , 扩容的算法

代码语言:java
复制
//newCapacity = oldCapacity + ((capacityIncrement > 0) ?
//capacityIncrement : oldCapacity); 就是扩容两倍. 
private void grow(int minCapacity) {
	// overflow-conscious code
	int oldCapacity = elementData.length;
	int newCapacity = oldCapacity + ((capacityIncrement > 0) ?
	capacityIncrement : oldCapacity);
	if (newCapacity - minCapacity < 0)
	newCapacity = minCapacity;
	if (newCapacity - MAX_ARRAY_SIZE > 0)
	newCapacity = hugeCapacity(minCapacity);
	elementData = Arrays.copyOf(elementData, newCapacity);
}

3. Vector 和 ArrayList 的比较

在这里插入图片描述
在这里插入图片描述

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. Vector 的基本介绍
  • 2. 源码分析
  • 3. Vector 和 ArrayList 的比较
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档