博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java知识点总结(Java容器-Vector)
阅读量:6188 次
发布时间:2019-06-21

本文共 654 字,大约阅读时间需要 2 分钟。

Vector

与ArrayList相似,但是Vector是同步的。所以说Vector是线程安全的动态数组。它的操作与ArrayList几乎一样。

ArrayList 和Vector是采用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,都允许直接序号索引元素,但是插入数据要设计到数组元素移动等内存操作,所以索引数据快插入数据慢,Vector由于使用了synchronized方法(线程安全)所以性能上比ArrayList要差,LinkedList使用双向链表实现存储,按序号索引数据需要进行向前或向后遍历,但是插入数据时只需要记录本项的前后项即可,所以插入数度较快!

  1. vector是线程同步的,所以它也是线程安全的,而arraylist是线程异步的,是不安全的。如果不考虑到线程的安全因素,一般用arraylist效率比较高。
  2. 如果集合中的元素的数目大于目前集合数组的长度时,vector增长率为目前数组长度的100%,而arraylist增长率为目前数组长度的50%.如过在集合中使用数据量比较大的数据,用vector有一定的优势。
  3. 如果查找一个指定位置的数据,vector和arraylist使用的时间是相同的,都是0(1),这个时候使用vector和arraylist都可以。而如果移动一个指定位置的数据花费的时间为0(n-i)n为总长度,这个时候就应该考虑到使用linklist,因为它移动一个指定位置的数据所花费的时间为0(1),而查询一个指定位置的数据时花费的时间为0(i)。

转载地址:http://mflda.baihongyu.com/

你可能感兴趣的文章
消息推送技术
查看>>
实战案例-- 用Java编写基础小程序
查看>>
Oracle 查询出来的数据取第一条
查看>>
基于maven的ssh框架一步一步搭建(二)
查看>>
如何成为技术专家
查看>>
Java System 类
查看>>
如何做好接口测试?【转载】
查看>>
#VyOS#Ex02
查看>>
jdk8中新的获取时间的方式
查看>>
常用命令所在的rpm包
查看>>
UltraEdit强大的搜索功能,有提示的正则匹配搜索匹配替换
查看>>
android ProgressDialog 不可点掉
查看>>
element-admin 点击侧边栏刷新当前路由
查看>>
rpm 的常规用法
查看>>
CodeIgniter通过hook的方式实现简单的权限控制
查看>>
Spring Boot中@ConfigurationProperties的使用
查看>>
MySQL与PostgreSQL的简单表关联更新
查看>>
Android 使用Javascript作为脚本计算器
查看>>
Android 贝塞尔曲线实践——旋转的七色花朵
查看>>
不得不知道的golang之sync.Mutex互斥锁源码分析
查看>>