Java岗大厂面试百日冲刺 - 日积月累,每日三题【Day07】——Java基础篇

简介: Java岗大厂面试百日冲刺 - 日积月累,每日三题【Day07】——Java基础篇

  大家好,我是陶然同学,软件工程大三明年实习。认识我的朋友们知道,我是科班出身,学的还行,但是对面试掌握不够,所以我将用这100多天更新Java面试题🙃🙃。


 不敢苟同,相信大家和我一样,都有一个大厂梦,作为一名资深Java选手,深知面试重要性,接下来我准备用100天时间,基于Java岗面试中的高频面试题,以每日3题的形式,带你过一遍热门面试题及恰如其分的解答。当然,我不会太深入,因为我怕记不住!!


 因此,不足的地方希望各位在评论区补充疑惑、见解以及面试中遇到的奇葩问法,希望这100天能够让我们有质的飞越,一起冲进大厂!!,让我们一起学(juan)起来!!!


请你讲一下Java 8的新特性


Lambda 表达式 —— Lambda允许把函数作为一个方法的参数(函数作为参数传递到方法中)

方法引用 —— 方法引用提供了非常有用的语法 可以直接引用已有Java类或对象(实例)的方法或构造器 与Lambda联合使用 方法引用可以使语言的构造更紧凑简洁 减少冗余代码

默认方法 —— 默认方法就是在一个接口里面有了一个实现的方法

Stream API —— 新添加的Stream API 把真正的函数式编程风格引入到Java中

Date Time API —— 加强对日期与时间的处理


请你说说HashMap底层原理


HashMap是以Key-Value方式进行数据存储的一种数据结构 在JDK1.7和1.8底层数据结构不一样1.7底层数据结构是:数组+链表 使用Entry类存储Key和Value 1.8底层数据结构是:数组+链表+红黑树 使用Node类存储Key和Value 我们来看看Node类源码:


a5927706a9974dd087641eba243b85f5.png


每一个节点都会保存自身的hash、key、和value以及下个节点 HashMap示意图:


ac5b214c19f04e43853bc2a149e42f89.png


HashMap本身的所有位置为null 所以在put操作时 回根据key的hash计算出一个index值 也就是这个元素将要插入的位置


举个例子:比如 put(“小牛肉”,20),我插入了一个 key 为 “小牛肉” value 为 20 的元素,这个时候我们会通过哈希函数计算出这个元素将要插入的位置,假设计算出来的结果是 2:


fcabb451061e40bd9c388d0f189f2930.png


Node类里面定义了一个next属性 那么为什么需要链表?

首先 数组的长度有限 在有限的数组上使用哈希 会造成哈希冲突 很有可能两个元素计算的index是

相同的 那么如何解决Hash冲突?拉链法 就是把hash后值相同放在同一条链表 例如:


2182354ea3284ad88b88157b4bf346cd.png

当然这里还有一个问题,那就是当 Hash 冲突严重时,在数组上形成的链表会变的越来越长,由于链表不支持索引,要想在链表中找一个元素就需要遍历一遍链表,那显然效率是比较低的。为此,JDK 1.8 引入了红黑树,当链表的长度大于 8 的时候就会转换为红黑树,不过,在转换之前,会先去查看 table 数组的长度是否大于 64,如果数组的长度小于 64,那么 HashMap 会优先选择对数组进行扩容 resize,而不是把链表转换成红黑树。

7b50ef6bbd71410d9c20fddef4169e4a.png


看下 JDK 1.8 下 HashMap 的完整示意图,应该画的比较清晰了:


23148d872039479dbdabdd1fdeabc588.png

请你说说hashCode()和equals()的区别,为什么重写equals()就要重写hashcod()


1.hashCode():获取哈希码 equals():比较两个对象是否相等


2.二者两个约定:如果两个对象相等 他们必须有相同的哈希码 若两个对象的哈希码相同 他们却不一定相等 也就是说 equal()比较两个对象相等时 hashCode一定相等 hashCode相等的两个对象equals()不一定相等


3.加分回答:由于hashCode()与equals()具有联动关系 equals()重写时 hashCode()进行重写 使得这两个方法始终满足相关的约定


相关文章
|
13天前
|
监控 Java 应用服务中间件
高级java面试---spring.factories文件的解析源码API机制
【11月更文挑战第20天】Spring Boot是一个用于快速构建基于Spring框架的应用程序的开源框架。它通过自动配置、起步依赖和内嵌服务器等特性,极大地简化了Spring应用的开发和部署过程。本文将深入探讨Spring Boot的背景历史、业务场景、功能点以及底层原理,并通过Java代码手写模拟Spring Boot的启动过程,特别是spring.factories文件的解析源码API机制。
42 2
|
1天前
|
Java 程序员
Java社招面试题:& 和 && 的区别,HR的套路险些让我翻车!
小米,29岁程序员,分享了一次面试经历,详细解析了Java中&和&&的区别及应用场景,展示了扎实的基础知识和良好的应变能力,最终成功获得Offer。
23 14
|
18天前
|
存储 算法 Java
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?
本文详解自旋锁的概念、优缺点、使用场景及Java实现。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
大厂面试高频:什么是自旋锁?Java 实现自旋锁的原理?
|
23天前
|
存储 缓存 Oracle
Java I/O流面试之道
NIO的出现在于提高IO的速度,它相比传统的输入/输出流速度更快。NIO通过管道Channel和缓冲器Buffer来处理数据,可以把管道当成一个矿藏,缓冲器就是矿藏里的卡车。程序通过管道里的缓冲器进行数据交互,而不直接处理数据。程序要么从缓冲器获取数据,要么输入数据到缓冲器。
Java I/O流面试之道
|
19天前
|
存储 缓存 Java
大厂面试必看!Java基本数据类型和包装类的那些坑
本文介绍了Java中的基本数据类型和包装类,包括整数类型、浮点数类型、字符类型和布尔类型。详细讲解了每种类型的特性和应用场景,并探讨了包装类的引入原因、装箱与拆箱机制以及缓存机制。最后总结了面试中常见的相关考点,帮助读者更好地理解和应对面试中的问题。
41 4
|
20天前
|
存储 Java 程序员
Java基础的灵魂——Object类方法详解(社招面试不踩坑)
本文介绍了Java中`Object`类的几个重要方法,包括`toString`、`equals`、`hashCode`、`finalize`、`clone`、`getClass`、`notify`和`wait`。这些方法是面试中的常考点,掌握它们有助于理解Java对象的行为和实现多线程编程。作者通过具体示例和应用场景,详细解析了每个方法的作用和重写技巧,帮助读者更好地应对面试和技术开发。
70 4
|
10天前
|
Java 开发者
Java多线程编程中的常见误区与最佳实践####
本文深入剖析了Java多线程编程中开发者常遇到的几个典型误区,如对`start()`与`run()`方法的混淆使用、忽视线程安全问题、错误处理未同步的共享变量等,并针对这些问题提出了具体的解决方案和最佳实践。通过实例代码对比,直观展示了正确与错误的实现方式,旨在帮助读者构建更加健壮、高效的多线程应用程序。 ####
|
1天前
|
缓存 Java 开发者
Java多线程编程的陷阱与最佳实践####
本文深入探讨了Java多线程编程中常见的陷阱,如竞态条件、死锁和内存一致性错误,并提供了实用的避免策略。通过分析典型错误案例,本文旨在帮助开发者更好地理解和掌握多线程环境下的编程技巧,从而提升并发程序的稳定性和性能。 ####
|
1天前
|
安全 Java 开发者
Java中的多线程编程:从基础到实践
本文深入探讨了Java多线程编程的核心概念和实践技巧,旨在帮助读者理解多线程的工作原理,掌握线程的创建、管理和同步机制。通过具体示例和最佳实践,本文展示了如何在Java应用中有效地利用多线程技术,提高程序性能和响应速度。
16 1
|
9天前
|
安全 Java 开发者
Java 多线程并发控制:深入理解与实战应用
《Java多线程并发控制:深入理解与实战应用》一书详细解析了Java多线程编程的核心概念、并发控制技术及其实战技巧,适合Java开发者深入学习和实践参考。
下一篇
无影云桌面