首页 > Java春招面试高频考点
头像
EileenZQR
编辑于 2021-04-03 18:41
+ 关注

Java春招面试高频考点

写在前面:

算是对自己最近经历的一些面试的小小总结吧,小张要继续加油呀🤣🤣

项目:

  • 介绍项目的背景、架构、功能、目前完成的情况、部署方案?
  • 项目实现过程中的难点以及如何解决的?
  • 哪个项目收获更大?
  • 为什么用xx框架/技术来实现?
  • 在项目中主要承担了哪些工作?
  • 如果你的项目中服务端同时有大量请求,如何处理?

Java基础:

  • String、StringBuffer、StringBuilder的区别?
  • JDK1.7和JDK1.8有哪些区别?
  • Java中有哪些常用的容器类?
  • HashMap底层是如何实现的?JDK1.8和JDK1.7的HashMap的实现有哪些区别?
  • HashMap扩容为什么都要扩展为原来的2倍?
  • 高并发情况下使用HashMap会出现哪些问题?如何解决?
  • JDK1.7中ConcurrentHashMap的底层结构?
  • JDK1.8对ConcurrentHashMap做了哪些改进?
  • JDK1.8中ConcurrentHashMap保证并发安全的原理?
  • ArrayList和LinkedList的区别?
  • LinkedList的底层数据结构?插入删除元素的时空复杂度分析?
  • ArrayList的扩容机制?
  • 什么是Fast-fail?
  • 什么是序列化?如何实现序列化?
  • transient关键字的作用?
  • Java中有哪些IO流?字节流和字符流如何进行转换?
  • Java的反射机制?为什么需要反射?反射主要用于哪些场景?
  • 使用反射创建实例和new一个对象的区别?
  • 讲一下线程池的作用?为什么需要线程池?创建线程为什么比较耗时?线程池的核心参数有哪些?线程池中创建一个线程的时机?

Java并发:

  • Java中如何创建一个线程?实现Collable接口和实现Runnable的区别?
  • 创建一个线程时,会在哪些区域分配空间?
  • Java中线程间通信的方式有哪些?
  • 保证线程同步的机制有哪些?
  • 什么是ThreadLocal?实现原理?
  • 什么是AQS?AQS有什么作用?常见的基于AQS的组件有哪些?
  • java的内存模型?
  • 指令重排序是什么?
  • happens-before规则是什么?作用?有哪些规则?
  • volatile关键字的作用?实现原理?
  • 什么是synchronized?实现原理?
  • synchronized可以修饰哪些内容,分别锁定的是什么?
  • JDK1.6后synchronized关键字底层做了哪些优化?
  • 如何基于双重检查锁实现单例模式?volatile关键字的作用?为什么要两次加锁?

JVM:

  • 运行时数据分区:
    • JVM将数据区域划分为哪些部分,分别存储哪些内容?
    • 哪些区域是线程私有的,哪些是线程公有的?
    • 什么是TLAB?作用?
  • 垃圾回收机制:
    • JVM运行时数据分区有哪些?分别存储哪些内容?有什么特点?
    • 垃圾回收主要回收哪些区域?
    • 如何判断一个对象是否可回收?
    • 可达性分析后发现一个对象不在引用链上,那它一定会被回收吗?
    • 垃圾回收算法有哪些?
    • 常用的垃圾回收器有哪些?
    • G1回收器采用了什么样的回收算法?
    • 什么时候会触发Full GC?
    • 服务器运行过程中频繁发生Full GC,可能存在哪些问题?如何排查?
  • 类加载机制:
    • 自定义一个String类,可以被加载到吗?为什么?
    • 什么是双亲委派机制?
    • 如果想要加载到自定义的String类,应该怎么做?(如何打破双亲委派机制?)
    • 哪些情况会触发类的初始化?
    • 类加载的过程?
    • 什么情况下两个类是相等的?

MySQL:

  • SQL执行过程、性能分析:
    • MySQL包括哪些组件?(连接器、查询缓存、分析器、优化器、执行器)(Server层+存储引擎)
    • 为什么不推荐使用查询缓存功能?为什么MySQL 8.0版本删除了查询缓存?
    • 查询sql语句的执行过程?
    • 更新sql语句的执行过程?
    • 什么是crash-safe?
    • MySQL实现crash-safe的原理?(binlog、redolog、undolog、WAL机制、两阶段提交)
    • 更新SQL语句执行流程中,总共需要写3个日志,这3个是不是都需要,能不能进行简化?
    • 两阶段提交的方式会存在什么问题?解决方法?
    • 什么是组提交?用于解决什么问题?
    • 假设事务提交过程中,MySQL进程突然奔溃,重启后是怎么保证数据不丢失的?
    • 如何查看SQL的执行情况?(执行计划、explain指令)
    • 如何在MySQL中查找效率慢的SQL语句呢?(慢查询日志)
  • 死锁:
    • MySQL的InnoDB存储引擎支持哪些类型的锁?
    • 什么是死锁?MySQL中哪些情况下会发生死锁?
    • 如何解决死锁?(超时等待、wait-for graph)
    • 如何避免死锁的发生?
    • 如何检查是否发生了死锁?(死锁日志)
  • 索引机制:
    • InnoDB存储引擎的索引机制底层采用了什么结构?
    • B+树的特点有哪些?
    • Hash索引和B+索引对比分析?
    • 添加索引时需要注意什么?什么情况下不适合添加索引?
    • 使用索引一定能够提高查询的性能吗?为什么?
    • 什么是最左前缀原则?
  • 事务机制:
    • 什么是事务?事务的特性?
    • 事务的隔离级别有哪几种?
    • 并发事务会带来哪些问题?不同的隔离级别分别可以避免哪些问题的发生?
    • 幻读发生时的情形?
    • MySQL默认的事务级别是什么?可以避免哪些问题?
    • 事务回滚在MySQL中是如何实现的?
  • MyISAM和InnoDB存储引擎有哪些区别?

计网:

  • TCP/UDP:
    • TCP和UDP的特点?
    • TCP三次握手的过程?
    • 四次挥手的过程?
    • 为什么需要三次握手?
    • 三次握手如果每次对方都没有收到会怎么样?分情况介绍。
    • 为什么连接的时候是三次握手,关闭的时候却是四次握手?
    • 挥手时客户端为什么最后还要等待2MSL?
    • 如果已经建立了连接,但是客户端突然出现故障了怎么办?(保活计时器)
    • TCP依靠哪些机制来保证可靠传输?
      • 数据分块传输
      • 数据包校验
      • 失序数据包重排序
      • 应答机制
      • 流量控制:滑动窗口机制(接收窗口)
      • 拥塞控制:慢开始、拥塞避免、快重传、快恢复(拥塞窗口)
      • 超时重传
    • 使用UDP时如果想要保证可靠性,可以如何实现?
    • TCP和UDP分别对应的应用层协议有哪些?
  • HTTP/HTTPS:
    • 如何理解HTTP协议是无状态的?HTTP如何保存用户状态?
    • Cookie的作用是什么?和Session有什么区别?
    • HTTP和HTTPS的区别?(安全性、资源消耗、端口等)
    • HTTPS的工作原理?
    • HTTP的常见状态码有哪些?分别表示什么?
  • OSI七层体系结构每一层的作用?以及每层常见的协议。
  • 浏览器输入URL回车后发生了什么?

操作系统:

  • 进程间通信的方式有哪些?基本原理?
    • 管道/匿名管道:
    • 有名管道:
    • 信号
    • 消息队列
    • 信号量
    • 共享内存
    • 套接字
  • 进程调度算法有哪些?
  • 死锁:
    • 什么是死锁?死锁产生的原因?死锁产生的必要条件?(互斥、不可剥夺、请求与保持、循环等待)
    • 死锁的处理基本策略和常用方法?
  • 页面置换算法有哪些?

Spring全家桶:

  • Spring和SpringBoot有什么区别吗?为什么需要SpringBoot?
  • 什么是MVC?SpringMVC处理请求的流程?
  • Spring中AOP的实现的方式有哪些?
  • Cglib和JDK动态代理的区别?
  • Spring运行过程中如何旋转使用的代理?
  • Spring中IoC的实现原理?
  • 单例Bean是并发安全的吗?为什么?
  • Spring中事务是如何实现的?
  • Spring中Controller是单例还是多例?如何保证并发的安全?

其他:

  • 排序算法:时空复杂度、实现原理?
  • 什么是分布式一致性算法?Raft算法的原理?
  • 一致性哈希算法?
  • HDFS的架构,读写流程?如果一个DataNode挂掉了怎么办?NameNode挂掉怎么办?如何容灾?
  • 什么是RPC?实现一个RPC框架主要需要考虑哪些方面?
  • and so on......
(至少要十分熟悉两三个框架/组件,可以是项目中用到的,也可以是目前比较主流的,比如Redis、Netty、Hadoop、RPC框架等)

更多模拟面试

全部评论

(9) 回帖
加载中...
话题 回帖

推荐话题

相关热帖

热门推荐