社区
Java SE
帖子详情
为什么Vector 在集合中保存大量的数据那比ArrayList更有优势?
xzhacker
2012-03-17 09:23:52
如果元素的数目超出了内部数组目前的长度它们都需要扩展内部数组的长度,Vector缺省情况下自动增长原来一倍的数组长度,ArrayList是原来的50%,
所以最后你获得的这个集合所占的空间总是比你实际需要的要大
。
亲问:不是应该vector这个集合所占空间总是比实际的要大吗?比如vector[99]和ArrayList[99]当再向他们一人插入一个元素,vector就占200个了,而ArrayList不就是150吗?
...全文
127
8
打赏
收藏
为什么Vector 在集合中保存大量的数据那比ArrayList更有优势?
如果元素的数目超出了内部数组目前的长度它们都需要扩展内部数组的长度,Vector缺省情况下自动增长原来一倍的数组长度,ArrayList是原来的50%,所以最后你获得的这个集合所占的空间总是比你实际需要的要大。 亲问:不是应该vector这个集合所占空间总是比实际的要大吗?比如vector[99]和ArrayList[99]当再向他们一人插入一个元素,vector就占200个了,而ArrayList不就是150吗?
复制链接
扫一扫
分享
转发到动态
举报
AI
作业
写回复
配置赞助广告
用AI写文章
8 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
xzhacker
2012-03-17
打赏
举报
回复
不是应该VECTOR开销貌似更大一点吗?
Lucky_BW
2012-03-17
打赏
举报
回复
[Quote=引用 3 楼 xzhacker 的回复:]
朋友这不是问题的关键啊!引用 1 楼 lucky_bw 的回复:
基本JDK1.7,之前版本会有所不同
ArrayList
int newCapacity = oldCapacity + (oldCapacity >> 1);
按你的例子,99+(99 >> 1)即新的容量为123
Vector
int newCapacity = oldCapacity + ((capaci……
[/Quote]
那你想问什么
xzhacker
2012-03-17
打赏
举报
回复
朋友这不是问题的关键啊![Quote=引用 1 楼 lucky_bw 的回复:]
基本JDK1.7,之前版本会有所不同
ArrayList
int newCapacity = oldCapacity + (oldCapacity >> 1);
按你的例子,99+(99 >> 1)即新的容量为123
Vector
int newCapacity = oldCapacity + ((capacityIncrement > 0) ? capacityIncrement……
[/Quote]
shift3325
2012-03-17
打赏
举报
回复
[Quote=引用 1 楼 lucky_bw 的回复:]
基本JDK1.7,之前版本会有所不同
ArrayList
int newCapacity = oldCapacity + (oldCapacity >> 1);
按你的例子,99+(99 >> 1)即新的容量为123
Vector
int newCapacity = oldCapacity + ((capacityIncrement > 0) ? capacityIncrement……
[/Quote]哦哦 集合还得加油学习 学习了。
Lucky_BW
2012-03-17
打赏
举报
回复
基本JDK1.7,之前版本会有所不同
ArrayList
int newCapacity = oldCapacity + (oldCapacity >> 1);
按你的例子,99+(99 >> 1)即新的容量为123
Vector
int newCapacity = oldCapacity + ((capacityIncrement > 0) ? capacityIncrement : oldCapacity);
Vector可以指定增长长度capacityIncrement,默认为0
你的例子在默认状态下,新的容量为198
xzhacker
2012-03-17
打赏
举报
回复
谢谢,我懂了
ZZZ5512536
2012-03-17
打赏
举报
回复
[Quote=引用 6 楼 xiaoliuliu2050 的回复:]
楼主的问题 我来回答!!!!!!!!!
正如楼主所说,vector 数据增长100% Arraylist 增长50%
我举个例子楼主就明白了:
vector v=new vector(); 假设默认目前的长度100个
list list1=new Arraylist(); 假设默认目前的长度100个 (指元素个数)
现在楼主要存储180个 元素……
[/Quote]
这个应该说的比较清楚了。
xiaoliuliu2050
2012-03-17
打赏
举报
回复
楼主的问题 我来回答!!!!!!!!!
正如楼主所说,vector 数据增长100% Arraylist 增长50%
我举个例子楼主就明白了:
vector v=new vector(); 假设默认目前的长度100个
list list1=new Arraylist(); 假设默认目前的长度100个 (指元素个数)
现在楼主要存储180个 元素
用vector 的话,则 vector 需要增加一倍 变成 200个就够了
但是用list 的话,100+50 不够用,还要再增加 75 现在就变成了225
这样的话,其实是vector 开销更小 !!!
总结,当存储大量数据时候,大量是什么意思,就好比 200 个空间 要存储 180 个一样,
这就叫做大量,如果是小于150 list可用 则不是大量了!!
java
集合
框架总结
ArrayList
类,LinkedList类,
Vector
类,Stack类
ArrayList
集合
类的使用方法(无同步性,线程不安全) [java] view plaincopyprint? "white-space:pre"> //
ArrayList
--- 实现了List接口,
ArrayList
是...
java
集合
框架
ArrayList
类,LinkedList类,
Vector
类,Stack类
ArrayList
集合
类的使用方法(无同步性,线程不安全) //
ArrayList
— 实现了List接口,
ArrayList
是容量大小可变的数组的实现
ArrayList
al = new
ArrayList
(); //将...
【Java基础之
集合
(一)】各种常用
集合
(Array、
ArrayList
、HashSet、HashMap、TreeMap等)分析对比
Java平台提供了一个全新的
集合
框架。“
集合
框架”主要由一组用来操作对象的接口组成。...可扩展为自定义
集合
类。 实现类:8个实现类(实线表示),对接口的具体实现。 在很大程度上,一旦您理解了
List(
ArrayList
,
Vector
,LinkedList),Set,Map的区别
Collection是最基本的
集合
接口,一个Collection代表一组Object,即Collection的元素。一些Collection允许相同的元素而另一些不行。一些能排序而另一些不行。Java JDK不能提供直接继承自Collection的类,Java JDK...
Java的
集合
类
4、List:
集合
中
的对象按照检索位置排序,可以有重复对象。 5、Map:
集合
中
每一个元素包含一对键-值对象,
集合
中
没有重复的键对象,值对象可以重复。 总结:无论对于
ArrayList
还是LinkedList, (1)仅对其遍...
Java SE
62,635
社区成员
307,269
社区内容
发帖
与我相关
我的任务
Java SE
Java 2 Standard Edition
复制链接
扫一扫
分享
社区描述
Java 2 Standard Edition
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章