JAVA HashMap常见面试难题有哪些?
- 内容介绍
- 文章标签
- 相关推荐
本文共计2803个文字,预计阅读时间需要12分钟。
1.+ 为什么我们建议在定义HashMap的时候,就指定它的初始化大小呢?答:在定义HashMap时指定初始大小,可以避免在后续添加元素时因扩容而导致的性能损耗。如果没有设置初始容量,系统会默认创建一个容量为16的集合。
1. 为什么我们建议在定义HashMap的时候,就指定它的初始化大小呢?
答:在当我们对HashMap初始化时,如果没有为其设置初始化容量,那么系统会默认创建一个容量为16的大小的集合。当我们向HashMap中添加元素时,如果HashMap的容量值超过了它的临界值(默认16*0.75=12)时,(0.75是HashMap的加载因子)HashMap将会重新扩容到下一个2的指数次幂(2^4=16 下一个2的指数次幂是2^5=32)。由于HashMap扩容要进行resize的操作,频繁的resize,会导致HashMap的性能下降,所以建议在确定HashMap集合的大小的情况下,指定其初始化大小,避免做过多的resize操作,导致性能下降。
2. HashMap什么时候进行扩容?
答:当我们不断的向HashMap中添加元素时,它会判断HashMap当前的容量值(当前元素的个数)是否超过了它的临界值(在没有指定其初始化大小时,默认16*0.75=12),如果添加的元素个数超过了临界值,它就会开始进行扩容。
本文共计2803个文字,预计阅读时间需要12分钟。
1.+ 为什么我们建议在定义HashMap的时候,就指定它的初始化大小呢?答:在定义HashMap时指定初始大小,可以避免在后续添加元素时因扩容而导致的性能损耗。如果没有设置初始容量,系统会默认创建一个容量为16的集合。
1. 为什么我们建议在定义HashMap的时候,就指定它的初始化大小呢?
答:在当我们对HashMap初始化时,如果没有为其设置初始化容量,那么系统会默认创建一个容量为16的大小的集合。当我们向HashMap中添加元素时,如果HashMap的容量值超过了它的临界值(默认16*0.75=12)时,(0.75是HashMap的加载因子)HashMap将会重新扩容到下一个2的指数次幂(2^4=16 下一个2的指数次幂是2^5=32)。由于HashMap扩容要进行resize的操作,频繁的resize,会导致HashMap的性能下降,所以建议在确定HashMap集合的大小的情况下,指定其初始化大小,避免做过多的resize操作,导致性能下降。
2. HashMap什么时候进行扩容?
答:当我们不断的向HashMap中添加元素时,它会判断HashMap当前的容量值(当前元素的个数)是否超过了它的临界值(在没有指定其初始化大小时,默认16*0.75=12),如果添加的元素个数超过了临界值,它就会开始进行扩容。

