java集合框架之List实现类的性能分析

面向接口编程:
接口类型  变量 =   new  实现类();
List  list = new ArrayList();
---------------------------------------------------------
List实现类特点和性能分析:
---------------------------------------------------------
三者共同的特点(共同遵循的规范):
   1):允许元素重复.
   2):记录元素的先后添加顺序.
---------------------------------------------------------
Vector类:     底层采用数组结构算法,方法都使用了synchronized修饰,线程安全,但是性能相对于ArrayList较低.

ArrayList类: 底层采用数组结构算法,方法没有使用synchronized修饰,线程不安全,性能相对于Vector较高.

ArrayList现在几乎已经取代了Vector的江湖地位.

为了保证ArrayList的线程安全,List list = Collections.synchronizedList(new ArrayList(...));获取线程安全的ArrayList类


LinkedList类:底层采用双向链表结构算法,方法没有使用synchronized修饰,线程不安全.

为了保证LinkedList的线程安全,List list = Collections.synchronizedList(new LinkedList(...));获取线程安全的LinkedList


数组结构算法和双向链表结构算法的性能问题:
    数组结构算法: 插入和删除操作速度低,查询和更改较快.
    链表结构算法: 插入和删除操作速度快,查询和更改较慢.
------------------------------------------------------------
使用的选择:
Vector类打死不用!即使要用选ArrayList类.
 如果删除和插入操作频繁,应该选择LinkedList类.
 如果查询操作频繁,应该使用ArrayList类.
 在开发中使用ArrayList较多,根据具体的需求环境来做选择.
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值