zoukankan      html  css  js  c++  java
  • Vector 、ArrayList、LinkedList比较

    这三者都可以随机访问,也就是支持通过索引查找数据。 都是有序(可以实现元素怎么进怎么出)

     Vector和ArrayList比较

    相同之处

    1 它们都是List

    它们都继承于AbstractList,并且实现List接口。

    3 它们都是通过数组实现的,本质上都是动态数组

    4 它们的默认数组容量是10

       

    不同之处

    1 线程安全性不一样

       ArrayList是非线程安全;
       而Vector是线程安全的,它的函数都是synchronized的,即都是支持同步的。
       ArrayList适用于单线程,Vector适用于多线程。

    2 对序列化支持不同

       ArrayList支持序列化,而Vector不支持;即ArrayList有实现java.io.Serializable接口,而Vector没有实现该接口。

    3 虽然默认容量都是10,但是Vector在构造函数中就初始化数组了,ArrayList是在add方法中,第一次添加元素时才初始化数组。
       

    4 容量增加方式不同

       逐个添加元素时,若ArrayList容量不足时,“新的容量”=“原始容量x3/2 ”。
       而Vector的容量增长与“增长系数有关”,若指定了“增长系数”,且“增长系数有效(即,大于0)”;那么,每次容量不足时,“新的容量”=“原始容量+增长系数”。若增长系数无效(即,小于/等于0),则“新的容量”=“原始容量 x 2”。

    ArrayList和LinkedList比较

    相同:

    1.它们都是List,可以通过索引访问。

    2.有序(可以实现怎么进怎么出)

    不同:

    1.底层实现不同:ArrayList是数组,LinkedList是双向链表

    2.ArrayList要扩容,linkedlist不用

  • 相关阅读:
    JVM运行参数
    JVM学习
    自己瞎写的小项目随笔
    git入门
    @ResponseBody 注释
    jquery 正则表达式 验证邮箱 手机号 座机号 身份证
    ORACLE计算一年的12个月份
    css 图片 文字居中
    Jquery 取值相关
    标题栏下拉菜单
  • 原文地址:https://www.cnblogs.com/xiaolovewei/p/9072504.html
Copyright © 2011-2022 走看看