集合框架面试题

1.HashMap原理?

不是线程安全的

a.扩容、并发问题

2.List/Set/Map的区别

ist有序元素可重复集合,所以有get()方法,获取指定位置的元素

set无序不重复集合,去重的时候用set

Map是一个键值对映射

3. HashMap和HashTable区别?

a. 相同点:数据结构都是基于哈希表

b. HashTable只接受非空对象,HashMap可以接受空对象

c.HashTable是线程安全的,HashMap不是

4.ConcurrentHashMap原理?(多线程情况下使用)

采用分段锁(锁分离)技术,它使用了多个锁来控制对hash表的不同部分进行的修改

5.HashSet原理?

是基于HashMap实现的,默认构造函数是构建一个初始容量为16,负载因子为0.75 的HashMap。封装了一个 HashMap 对象来存储所有的集合元素,所有放入 HashSet 中的集合元素实际上由 HashMap 的 key 来保存,而 HashMap 的 value 则存储了一个 PRESENT,它是一个静态的 Object 对象。

6.TreeSet原理?

元素有序,掺入/删除高效

TreeSet在保证元素唯一性的基础上,好可以对元素进行排序。

底层原理是基于TreeMap来实现的。所以底层机构是红黑树,和HashSet不同的是不需要重写HashCode()和equlas()方法,因为他是靠比较器来去重。因为结构也是红黑树,所以每次插入都会遍历比较来寻找节点插入位置,如果发现某个节点的值是一样的就会覆盖、

NavigableSet(可导航可以按照从小到大排好)里面的实现是个treeMap(红黑树)

7. equals/hashCode区别/何时使⽤?

HashCode的约定:

1、如果两个对象equals,Java运行时环境会认为他们的hashcode一定相等。 

2、如果两个对象不equals,他们的hashcode有可能相等。 

3、如果两个对象hashcode相等,他们不一定equals。 

4、如果两个对象hashcode不相等,他们一定不equals。

区别:

1、equals方法用于比较对象的内容是否相等(覆盖以后)

2、hashcode方法只有在集合中用到

3.当覆盖了equals方法时,比较对象是否相等将通过覆盖后的equals方法进行比较(判断对象的内容是否相等)

4、将对象放入到集合中时,首先判断要放入对象的hashcode值与集合中的任意一个元素的hashcode值是否相等,如果不相等直接将该对象放入集合中。如果hashcode值相等,然后再通过equals方法判断要放入对象与集合中的任意一个对象是否相等,如果equals判断不相等,直接将该元素放入到集合中,否则不放入。

8.ArrayList/LinkedList区别?

ArrayList是一个可以重新扩容的基于数组的实现,查询快

LinkedList基于双向链表的List实现,在添加和删除元素时具有比ArrayList更好的性能(用于队列情况,访问头元素和尾元素,或者插入一个元素时)

9.哪些集合类是线程安全的?

HashTable /ConcurrentHashSet

10.如何保证⼀个集合类不被修改?

使用Collections.ummodifiableXXX(list/map)方法转化为不可变的集合类

使用Guava的ImmutableXXX 的方法

11.ArrayList/Vector的区别?

a.ArrayList基于数组的自动扩容的实现

b.Vetor线程安全,但是慢(被废弃了);Arraylist不安全,但是效率高

12. 说⼀些常⻅的List/Set/Map实现?

ArrayList和 LinkedList

HashSet、TreeSet、LinkedHashSet

HashMap、TreeMap、LinkedHashMap、ConcurrentHashMap

13.Collection和Collections有什么区别?

• X是类名的话,Xs就是与之相关的⼯具⽅法集合

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,406评论 6 503
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,732评论 3 393
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,711评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,380评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,432评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,301评论 1 301
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,145评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,008评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,443评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,649评论 3 334
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,795评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,501评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,119评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,731评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,865评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,899评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,724评论 2 354