-
垃圾回收器的基本原理是什么?垃圾回收器可以马上回收内存吗?有什么办法主动通知虚拟机进行垃圾回收?
-
Java 中会存在内存泄漏吗,请简单描述
-
深拷贝和浅拷贝。
-
System.gc() 和 Runtime.gc() 会做什么事情?
-
finalize() 方法什么时候被调用?析构函数 (finalization) 的目的是什么?
-
如果对象的引用被置为 null,垃圾收集器是否会立即释放对象占用的内存?
-
串行(serial)收集器和吞吐量(throughput)收集器的区别是什么?
-
在 Java 中,对象什么时候可以被垃圾回收?
-
简述 Java 内存分配与回收策略以及 Minor GC 和 Major GC。
-
VM 的永久代中会发生垃圾回收么?
-
Java 中垃圾收集的方法有哪些?
-
什么是类加载器,类加载器有哪些?
-
类加载器双亲委派模型机制?
==================================================================
并发是重点的重点,记得有一次面试关于并发问题面试官死磕了我半个小时,从锁机制到线程池被安排的明明白白的。
关注后私信(答案)即可免费获取!
-
Synchronized 用过吗,其原理是什么?
-
你刚才提到获取对象的锁,这个“锁”到底是什么?如何确定对象的锁?
-
什么是可重入性,为什么说 Synchronized 是可重入锁?
-
VM 对 Java 的原生锁做了哪些优化?48
-
为什么说 Synchronized 是非公平锁?49
-
什么是锁消除和锁粗化?49
-
为什么说 Synchronized 是一个悲观锁?乐观锁的实现原理又是什么?什么是 CAS,它有什么特性?
-
乐观锁一定就是好的吗?
-
跟 Synchronized 相比,可重入锁 ReentrantLock 其实现原理有什么不同?
-
那么请谈谈 AQS 框架是怎么回事儿?
-
请尽可能详尽地对比下 Synchronized 和 ReentrantLock 的异同。
-
ReentrantLock 是如何实现可重入性的?
-
除了 ReetrantLock,你还接触过 JUC 中的哪些并发工具?
-
请谈谈 ReadWriteLock 和 StampedLock。
-
如何让 Java 的线程彼此同步?你了解过哪些同步器?请分别介绍下。
-
CyclicBarrier 和 CountDownLatch 看起来很相似,请对比下呢?
-
Java 线程池相关问题
-
Java 中的线程池是如何实现的?
-
创建线程池的几个核心构造参数?
-
线程池中的线程是怎么创建的?是一开始就随着线程池的启动创建好的吗?
-
既然提到可以通过配置不同参数创建出不同的线程池,那么 Java 中默认实现好的线程池又有哪些呢?请比较它们的异同
-
如何在 Java 线程池中提交线程?
-
什么是 Java 的内存模型,Java 中各个线程是怎么彼此看到对方的变量的?
-
请谈谈 volatile 有什么特点,为什么它能保证变量对所有线程的可见性?
-
既然 volatile 能够保证线程间的变量可见性,是不是就意味着基于 volatile 变量的运算就是并发安全的?
-
请对比下 volatile 对比 Synchronized 的异同。
-
请谈谈 ThreadLocal 是怎么解决并发安全的?
-
很多人都说要慎用 ThreadLocal,谈谈你的理解,使用 ThreadLocal 需要注意些什么?
=====================================================================
我相信大家都用过Spring吧,身为开源框架他的重要性毋庸置疑,IOC、AOP两大必问核心,从注解到标签都有可能问到。
-
1、什么是 Spring 框架?Spring 框架有哪些主要模块?
-
2、使用 Spring 框架能带来哪些好处?
-
3、什么是控制反转(IOC)?什么是依赖注入?
-
4、请解释下 Spring 框架中的 IoC?
-
5、BeanFactory 和 ApplicationContext 有什么区别?
-
6、Spring 有几种配置方式?
-
7、如何用基于 XML 配置的方式配置 Spring?
-
8、如何用基于 Java 配置的方式配置 Spring?
-
9、怎样用注解的方式配置 Spring?
-
10、请解释 Spring Bean 的生命周期?
-
11、Spring Bean 的作用域之间有什么区别?
-
12、什么是 Spring inner beans?
-
13、Spring 框架中的单例 Beans 是线程安全的么?
-
14、请举例说明如何在 Spring 中注入一个 Java Collection?
-
15、如何向 Spring Bean 中注入一个 Java.util.Properties?
-
16、请解释 Spring Bean 的自动装配?
-
17、请解释自动装配模式的区别?
-
18、如何开启基于注解的自动装配?
-
19、请举例解释@Required 注解?
-
20、请举例解释@Autowired 注解?
-
21、请举例说明@Qualifier 注解?
-
22、构造方法注入和设值注入有什么区别?
-
23、Spring 框架中有哪些不同类型的事件?
-
24、FileSystemResource 和 ClassPathResource 有何区别?
-
25、Spring 框架中都用到了哪些设计模式?
===================================================================
记得最清楚的是单例模式的懒汉和饿汉模式,这个考察的方向是一般是固定的,当然不排除面试官考察通知工作中遇到的问题(同学就是这样,自己工作不会的就狂问应聘的,心疼面试人员)。
-
1.请列举出在 JDK 中几个常用的设计模式?
-
2.什么是设计模式?你是否在你的代码里面使用过任何设计模式?
-
3.Java 中什么叫单例设计模式?请用 Java 写出线程安全的单例模式
-
4.在 Java 中,什么叫观察者设计模式(observer design pattern)?
-
5.使用工厂模式最主要的好处是什么?在哪里使用?
-
6.举一个用 Java 实现的装饰模式(decorator design pattern)?它是作用于对象层次还是类
层次?
-
7.在 Java 中,为什么不允许从静态方法中访问非静态变量?
-
8.设计一个 ATM 机,请说出你的设计思路?
-
9.在 Java 中,什么时候用重载,什么时候用重写?
-
10.举例说明什么情况下会更倾向于使用抽象类而不是接口
=========================================================================
最近springboot和springcloud的占比越来越重,因为他们最受中小企业欢迎,学会了它们最低也饿不死了哈哈。
-
什么是 Spring Boot?
-
Spring Boot 有哪些优点?
-
什么是 JavaConfig?
-
如何重新加载 Spring Boot 上的更改,而无需重新启动服务器?
-
Spring Boot 中的监视器是什么?
-
如何在 Spring Boot 中禁用 Actuator 端点安全性?
-
如何在自定义端口上运行 Spring Boot 应用程序?
-
什么是 YAML?
-
如何实现 Spring Boot 应用程序的安全性?
-
如何集成 Spring Boot 和 ActiveMQ?
-
如何使用 Spring Boot 实现分页和排序?
-
什么是 Swagger?你用 Spring Boot 实现了它吗?
-
什么是 Spring Profiles?
-
什么是 Spring Batch?
-
什么是 FreeMarker 模板?
-
如何使用 Spring Boot 实现异常处理?
-
您使用了哪些 starter maven 依赖项?
-
什么是 CSRF 攻击?
-
什么是 WebSockets?
-
什么是 AOP?
-
什么是 Apache Kafka?
-
我们如何监视所有 Spring Boot 微服务?
==========================================================================
-
什么是 Spring Cloud?
-
使用 Spring Cloud 有什么优势?
-
服务注册和发现是什么意思?Spring Cloud 如何实现?
-
负载平衡的意义什么?
-
什么是 Hystrix?它如何实现容错?
-
什么是 Hystrix 断路器?我们需要它吗?
-
什么是 Netflix Feign?它的优点是什么?
-
什么是 Spring Cloud Bus?我们需要它吗?
============================================================================
===================================================================
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
如果你觉得这些内容对你有帮助,可以扫码获取!!(备注Java获取)
总结:绘上一张Kakfa架构思维大纲脑图(xmind)
其实关于Kafka,能问的问题实在是太多了,扒了几天,最终筛选出44问:基础篇17问、进阶篇15问、高级篇12问,个个直戳痛点,不知道如果你不着急看答案,又能答出几个呢?
若是对Kafka的知识还回忆不起来,不妨先看我手绘的知识总结脑图(xmind不能上传,文章里用的是图片版)进行整体架构的梳理
梳理了知识,刷完了面试,如若你还想进一步的深入学习解读kafka以及源码,那么接下来的这份《手写“kafka”》将会是个不错的选择。
-
Kafka入门
-
为什么选择Kafka
-
Kafka的安装、管理和配置
-
Kafka的集群
-
第一个Kafka程序
-
Kafka的生产者
-
Kafka的消费者
-
深入理解Kafka
-
可靠的数据传递
-
Spring和Kafka的整合
-
SpringBoot和Kafka的整合
-
Kafka实战之削峰填谷
-
数据管道和流式处理(了解即可)
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门即可获取!
Kafka的集群
-
第一个Kafka程序
-
Kafka的生产者
-
Kafka的消费者
-
深入理解Kafka
-
可靠的数据传递
-
Spring和Kafka的整合
-
SpringBoot和Kafka的整合
-
Kafka实战之削峰填谷
-
数据管道和流式处理(了解即可)
[外链图片转存中…(img-rbyIEP4Y-1712477945623)]
[外链图片转存中…(img-GHssbhV6-1712477945624)]
《一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码》,点击传送门即可获取!