结构体系图

List

ArrayList、LinkedList、Vector有什么区别?
  • ArrayList

    • 只能装入引用对象(基本类型要转换为封装类);
    • 线程不安全;
    • 底层由数组实现(顺序表),因为由顺序表实现,所以会具备顺序表的特点,如:需要声明长度、超出长度时需要进行扩容、不适合频繁的移动删除元素、检索元素快;
    • capacity默认为10,超出时,capacity自动增长0.5倍(oldCapacity >> 1)
  • Vector:
    • 只能装入引用对象(基本类型要转换为封装类);
    • Vector通过synchronized方法保证线程安全;
    • 底层也由数组实现;
    • capacity默认为10(在构造方法中),超出时增长capacityIncrement的量,capacityIncrement小于等于0时,则增长1倍((capacityIncrement > 0) ? capacityIncrement : oldCapacity)
  • LinkedList
    • 只能装入引用对象(基本类型会转换为封装类);
    • 线程不安全;
    • 底层实现为链表,具备链表的特点,如:不用声明长度、检索性能较差,但是插入移动删除较快。
    • 链表通过Node对象实现
ArrayList的扩容消耗

由于ArrayList使用
elementData = Arrays.copyOf(elementData, newCapacity);
进行扩容,而
每次都会重新创建一个newLength长度的数组,所以扩容的空间复杂度为O(n),时间复杂度为O(n)

Arrays.asList方法后的List可以扩容吗?

不能,asList返回的List为只读的。其原因为:asList方法返回的ArrayList是Arrays的一个内部类,并且没有实现add,remove等操作

而在AbstractList中,add操作

如何使List线程安全

Collections.synchronizedList(list);
或者使用手动的方法保护线程安全。

List是有序的吗?

这里的有序指有序性,有序或无序是指是否按照其添加的顺序来存储对象,List是有序的。

List怎么实现排序?

实现排序,可以使用自定义排序
list.sort(new Comparator(){...})
或者使用Collections进行快速排序
Collections.sort(list)

List和Array之间如何互相转换?
  • Array转List:List list = new ArrayList(array);
  • List转Array:Object [] objects = list.toArray();

Set

Set与List有什么区别?
  • Set

    • 只能装入引用对象(基本类型要转换为封装类);
    • 线程不安全
    • 较List,是无序的(无法保证添加的顺序),而且元素不能重复
    • 底层使用了map进行实现(HashMap&LinkedHashMap),借用map的key不能重复的特性,来实现不重复性。

HashSet、LinkedHashSet、TreeSet的区别?

都无法保证线程安全,底层都使用map实现不重复性(所以特性也在map中),Set都不能使用get(index)的方法获取元素,只能使用iterator进行获取。其中:

  • HashSet

    • 使用HashMap,无法保证有序性。
  • LinkedHashSet
    • 使用LinkedHashMap,可以保证有序性
  • TreeSet
    • 使用NavigableMap,可以使用Comparator来控制顺序
如何使Set线程安全

Collections.synchronizedSet(set);

Map

HashMap、LinkedHashMap、Hashtable、TreeMap的区别?
  • HashMap

    • 线程不安全
    • 允许有一个key为null
    • 通过hash算法,来确定key是否存在
    • 不能保证有序性
    • 默认大小为16,每次扩容默认增大1倍。默认情况下,数组大小为16,那么当HashMap中元素个数超过16*0.75=12(这个值就是代码中的threshold值,也叫做临界值)的时候,就把数组的大小扩展为 2*16=32,即扩大一倍。
  • LinkedHashMap
    HashMap的子类,将结构与操作更改为链表形式

    • 线程不安全
    • accessOrder默认fasle,可以保证有序性
    • 在HashMap的线性单向链表的基础上,内部维护了一个双向链表
  • Hashtable
    • 父类为Dictionary,与HashMap不同
    • 线程安全,方法通过synchronized同步
    • key&value都不能为null
    • 不能保证有序性
    • 默认大小为11,其余与HashMap一致
  • TreeMap
    • 线程不安全
    • 内部使用红黑树,需要key实现Comparable接口
    • 可以定义Comparator控制顺序
    • 迭代遍历时使用中序遍历
如何使Map线程安全

Collections.synchronizedMap(map);

什么样的对象适合做为键,有什么要求?

String、Interger这样的类是final类型的,具有不可变性,且重写了equals()和hashCode()方法。换言之,做为key的对象,不可变性是必要的,因为要计算hashCode(),要防止放入时和取出时hashcode不一致。此外还需要重写equals()和hashCode()方法,用于比较对象一致性。

HashMap初始化传入的容量参数的值就是HashMap实际分配的空间么?

不是,是比传入容量参数值大的最小的2的n次方,比如传入6,实际分配8。

HashMap的底层数据结构是什么?

是一个数组,结合了顺序表+单向链表的形式,内部的每一个节点都是Node对象

附录

推荐几篇描述map原理还不错的文章

Java中常用的数据结构类的更多相关文章

  1. java中常用的工具类(三)

    继续分享java中常用的一些工具类.前两篇的文章中有人评论使用Apache 的lang包和IO包,或者Google的Guava库.后续的我会加上的!谢谢支持IT江湖 一.连接数据库的综合类       ...

  2. java中常用的工具类(二)

    下面继续分享java中常用的一些工具类,希望给大家带来帮助! 1.FtpUtil           Java   1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 ...

  3. java中常用的工具类(一)

    我们java程序员在开发项目的是常常会用到一些工具类.今天我汇总了一下java中常用的工具方法.大家可以在项目中使用.可以收藏!加入IT江湖官方群:383126909 我们一起成长 一.String工 ...

  4. java中常用的数据结构--Collection接口及其子类

    java中有几种常用的数据结构,主要分为Collection和map两个主要接口(接口只提供方法,并不提供实现),而程序中最终使用的数据结构是继承自这些接口的数据结构类. 一.集合和数组的区别 二.C ...

  5. Java基础学习(五)-- Java中常用的工具类、枚举、Java中的单例模式之详解

    Java中的常用类 1.Math : 位于java.lang包中 (1)Math.PI:返回一个最接近圆周率的 (2)Math.abs(-10):返回一个数的绝对值 (3)Math.cbrt(27): ...

  6. java中常用的帮助类。加快开发速度

    数据库帮助类 package com.cwnu.uitl; import java.sql.*; /** * 数据库基础操作实现类 * * @author BlackWinter * * @date ...

  7. java中常用的数据结构--Map

    一.定义: 将键映射到值的对象. 地图不能包含重复的键; 每个键可以映射到最多一个值. public interface Map<K,V> 请注意!!!, Map 没有继承 Collect ...

  8. java中常用的包、类、以及包中常用的类、方法、属性----sql和text\swing

    java中常用的包.类.以及包中常用的类.方法.属性 常用的包 java.io.*; java.util.*; java.lang.*; java.sql.*; java.text.*; java.a ...

  9. java 中常用的类

    java 中常用的类 Math Math 类,包含用于执行基本数学运算的方法 常用API 取整 l  static double abs(double  a) 获取double 的绝对值 l  sta ...

随机推荐

  1. [GitHub]第八讲:GitHub Pages

    Github Pages 是 github 公司提供的免费的静态网站托管服务,用起来方便而且功能强大,不仅没有空间限制,还可以绑定自己的域名.在 https://pages.github.com/ 首 ...

  2. hive中与hbase外部表join时内存溢出(hive处理mapjoin的优化器机制)

    与hbase外部表(wizad_mdm_main)进行join出现问题: CREATE TABLE wizad_mdm_dev_lmj_edition_result as select *  from ...

  3. UNIX环境高级编程——标准I/O库函数和Unbuffered I/O函数

    以写文件为例,C标准I/O库函数(printf(3) .putchar(3) .fputs(3) )与系统调用write(2) 的关 系如下图所示. 库函数与系统调用的层次关系 open .read ...

  4. GDAL书籍

    GDAL的书籍经过快两年的编写修改,终于出版发行了,有需要的同学可以到下面的网址进行购买. 购买地址: 亚马逊:http://www.amazon.cn/GDAL%E6%BA%90%E7%A0%81% ...

  5. SwiftyiRate中文说明

    SwiftyiRate Github SwiftyiRate Swift语言实现的app内评分,简单易用. Requirements Integration Usage Initialization ...

  6. Java Swing 之Timer配合JProgressBar的使用

    Timer作为java开发中常用的一个定时工具,配合JProgressBar使用起来还真是方便,只需要调用timer.start()方法就能激活并运行,然后调用stop()方法便能停止,还可以再次通过 ...

  7. Leetcode_114_Flatten Binary Tree to Linked List

    本文是在学习中的总结,欢迎转载但请注明出处:http://blog.csdn.net/pistolove/article/details/42744919 Given a binary tree, f ...

  8. Java-Iterator总结

    纸上得来终觉浅,绝知此事要躬行  --陆游    问渠那得清如许,为有源头活水来  --朱熹 迭 代器是一种设计模式,它是一个对象,它可以遍历并选择序列中的对象,而开发人员不需要了解该序列的底层结构. ...

  9. 省市联动 纯html+js

    在js里面声明所有数据,并根据html的select事件触发js实现填充对应的数据到下拉框. 代码 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 ...

  10. C++中的虚函数表是什么时期建立的?

    虚函数表是在什么时期建立的? 最近参加阿里巴巴公司的内推,面试官问了“虚函数表是在什么时期建立的?”.因为以前对虚函数表的理解不够多,所以就根据程序构建(Build)的四个过程(预编译.编译.汇编和链 ...