集合、流、多线程的总结,不是底层,适用于入行不久的同志们闲的时候看,不是很详细,主要是流程性的东西

在接触java之初,面试最常问,开发最常用的东西
首先就是集合
看集合要理清思路,区分类别,其实常用的也就是这两个 List Map Set
根据这两个接口延伸出了N个实现类,也就是我们实际中使用的集合:
List
1.ArrayList:ArrayList为什么是增删慢,查询快,因为底层是数组;那么为什么又能添加数据呢,ArrayList的底层数据默认长度是10,等等,我写过,自己去看。
2.linkedList:linkedlist底层是链表结构,所以就实现了增删方便但是查询的时候没有索引所以很慢,然后再自己去看链表结构咋实现的,我忘了。
然后就是Map
1.hashMap:永恒之问,怎么判断key值唯一的,key的hash值,那么hash值一出来,哈希表就跟着来了,自己去查。
2.linkedHashMap:有序map来了,为啥linkedHashMap是有序的呢,他是怎么做到的呢,因为他是双链表的结构,多的一层链表就是用来记录插入顺序的,然后根据插入顺序返回
3.HashTable和它的子类properties,有兴趣自己去看看吧,不咋用,也没咋问过。
4.ConcurrentHashMap:这个是我在用的,因为前段时间多线程,所以用的这个,用hashtable怕死,所以ConcurrentHashMap应运而生了,里面有个锁分段机制https://blog.csdn.net/qq_41737716/article/details/90549847,然后为了内容的可见性使用了volatile,自己去看看吧
5.Map的遍历方式,增强for,然后是迭代,要么整成set再遍历!
然后set
set问的比较多
什么hashSet linkedHashSet set咋遍历,自己去看看吧,打字手太累了。反正都是hash跟上面差不多。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值