欢迎光临散文网 会员登陆 & 注册

Java面经

2023-06-23 21:56 作者:UCLmsc  | 我要投稿

一、Java

(一)基础

  • Java 中的几种基本数据类型是什么?对应的包装类型是什么?各自占用多少字节呢?

  • String 、 StringBuffer 和 StringBuilder 的区别是什么? String 为什么是不可变的?

  • String s1 = new String("abc");这段代码创建了几个字符串对象?

  • == 与 equals?hashCode 与 equals ?

  • 包装类型的缓存机制了解么

  • 自动装箱与拆箱了解吗?原理是什么?

  • 深拷贝和浅拷贝区别了解吗?什么是引用拷贝?

  • 谈谈对 Java 注解的理解,解决了什么问题?

  • Exception 和 Error 有什么区别?

  • Java 反射?反射有什么缺点?你是怎么理解反射的(为什么框架需要反射)?

  • Java 泛型了解么?什么是类型擦除?介绍一下常用的通配符?

  • 内部类了解吗?匿名内部类了解吗?

  • BIO,NIO,AIO 有什么区别?

(二)Java集合框架

  • 说说 List,Set,Map 三者的区别?三者底层的数据结构?

  • 有哪些集合是线程不安全的?怎么解决呢?

  • 比较 HashSet、LinkedHashSet 和 TreeSet 三者的异同

  • HashMap 和 Hashtable 的区别?HashMap 和 HashSet 区别?HashMap 和 TreeMap 区别?

  • HashMap 的底层实现

  • HashMap 的长度为什么是 2 的幂次方

  • ConcurrentHashMap 和 Hashtable 的区别?

  • ConcurrentHashMap 线程安全的具体实现方式/底层具体实现

(三)JVM

  • jvm 内存结构

  • jvm 调优参数

  • 什么是类加载?何时类加载?类加载流程?

  • 知道哪些类加载器。类加载器之间的关系?

  • 类加载器的双亲委派了解么?结合 Tomcat 说一下双亲委派(Tomcat 如何打破双亲委托机制?...)。

  • 为什么需要双亲委派

  • Java 内存模型

  • 栈中存放什么数据,堆中呢?

  • 大对象放在哪个内存区域

  • 堆区如何分类

  • 垃圾回收有哪些算法

  • GC 的全流程

  • GC 中老年代用什么回收方法?

(四)多线程

  • 线程和进程的区别。

  • 什么是上下文切换?

  • 什么是线程死锁?如何避免死锁?

  • 乐观锁和悲观锁了解么?

  • 说说 sleep() 方法和 wait() 方法区别和共同点?

  • Java 线程池有哪些参数?阻塞队列有几种?拒绝策略有几种?新线程添加的流程?

  • 实现 Runnable 接口和 Callable 接口的区别。

  • 讲一下 JMM(Java 内存模型)。volatile 关键字解决了什么问题?说说 synchronized 关键字和 volatile 关键字的区别。

  • AQS 原理了解么?AQS 组件有哪些?

  • 用过 CountDownLatch 么?什么场景下用的?

二、数据库(MySQL + Redis)

(一)基础

  • 非关系型数据库和关系型数据库的区别?

  • 事务的四大特性了解么?

  • MySQL 事务隔离级别?默认是什么级别?

  • 乐观锁与悲观锁的区别?

  • MySQL 数据库两种存储引擎的区别?

(二)索引

  • 为什么索引能提高查询速度?

    • 聚集索引和非聚集索引的区别?非聚集索引一定回表查询吗?

    • 索引这么多优点,为什么不对表中的每一个列创建一个索引呢?(使用索引一定能提高查询性能吗?)

    • 索引底层的数据结构了解么?Hash 索引和 B+树索引优劣分析

    • B+树做索引比红黑树好在哪里?

    • 最左前缀匹配原则了解么?

    • 什么是覆盖索引

    (三)进阶

    • 一条 SQL 语句在 MySQL 中如何执行的?

      • explain 命令了解么?

      • 简单说一下 SQL 调优思路。

      • 简单说一下大表优化的思路。

      • 分库分表了解么?为什么要分库分表?有哪些常见的分库分表工具(sharding-jdbcTShardingMyCAT...)?

      (四)Redis

      • 分布式缓存常见的技术选型方案有哪些?说一下 Redis 和 Memcached 的区别和共同点

        • 说一下有缓存情况下查询数据和修改数据的流程。

        • Redis 有哪些数据结构?SDS 了解么?

        • Redis 内存满了怎么办?

        • Redis 内存淘汰算法除了 LRU 还有哪些?

        • Redis 给缓存数据设置过期时间有啥用?Redis 是如何判断数据是否过期的呢?

        • Redis 事务了解么?(Redis 可以通过 MULTI,EXEC,DISCARD 和 WATCH 等命令来实现事务功能)

        • 缓存穿透和缓存雪崩问题了解么?有哪些解决办法?

        • 如何基于 Redis 实现分布式锁?

        三、网络

        • OSI 与 TCP/IP 各层的结构与功能,都有哪些协议?为什么网络要分层?

          • 计算机网络的一些常见状态码

          • ping 所使用的协议

          • TCP 的三次握手与四次挥手的内容?TCP 为什么连接是三次握手而断开是四次握手?

          • TCP 与 UDP 的区别及使用场景

          • TCP 是如何保证传输的可靠性?

          • 一次完整的 HTTP 请求所经的步骤

          • HTTP 协议了解么?HTTP 是基于 TCP 还是 UDP 的?

          • HTTP 报文的内容简单说一下!HTTP 请求报文和响应报文中有哪些数据?

          • HTTP 和 HTTPS 的区别了解么?

          • HTTP 请求有哪些常见的状态码?

          • HTTP 长连接和短连接了解么?

          • Cookie 和 Session 的关系

          • URI 和 URL 的区别是什么?

          四、操作系统

          • 进程和线程的区别

            • 进程有哪几种状态?

            • 进程间的通信方式

            • 线程间的同步的方式

            • 进程的调度算法

            • 什么是死锁?死锁的四个必要条件,解决死锁的方法

            • 常见的内存管理机制,快表和多级页表

            • 分页机制和分段机制的共同点和区别

            • CPU 寻址了解吗?为什么需要虚拟地址空间?

            • 虚拟内存(Virtual Memory)

            • 页面置换算法

            五、算法与数据结构

            (一)算法

            • LRU 算法了解吗?你能实现一个吗?

            • 写排序算法(快排、堆排)

            • 使用数组实现一个栈

            • 使用数组实现一个队列

            • 实现一个链表,反转链表

            (二)数据结构

            • 数组 vs 链表

              • 栈的应用场景

              • 队列的分类、应用场景

              • 红黑树的特点、红黑树 vs 二叉查找树

              • 哈希表、哈希表应用场景

              • 布隆过滤器了解吗?

              六、系统设计

              (一)设计模式

              • 何为设计模式?有哪些常见的设计模式?

              • 单例模式了解么?说一下单例模式的使用场景。手写一个单例模式的实现。

              • 观察者模式了解么?说一下观察者模式的使用场景。

              • 工厂模式了解么?说一下工厂模式的使用场景。

              • 责任链模式了解么?哪些开源项目(Netty、MyBatis ...)中用到了责任链模式?怎么用的?

              • SOLID 原则了解么?简单谈谈自己对于单一职责原则和开闭原则的理解。

              • 阅读 Spring 源码的时候什么设计模式最让你影响深刻?能简单讲讲吗?

              (二)常见框架

              Spring

              • 什么是 Spring 框架?

              • 列举一些重要的 Spring 模块?

              • 谈谈自己对于 Spring IoC 和 AOP 的理解

              • Spring Bean 的生命周期说一下

              • Spring 中的 bean 的作用域有哪些?

              • 拦截器和过滤器了解么?

              • Spring 动态代理默认用哪一种

              • hibernate 和 mybatis 区别

              • Spring Boot 和 Spring 的区别

              • 说出使用 Spring Boot 的主要优点

              • 什么是 Spring Boot Starter?

              • 介绍一下@SpringBootApplication 注解

              • Spring Boot 的自动配置是如何实现的?

              • Spring Boot 支持哪些嵌入式 web 容器?

              Netty

              • BIO,NIO 和 AIO 有啥区别?

              • Netty 是什么?为啥不直接用 NIO 呢?

              • 为什么要用 Netty?Netty 应用场景了解么?

              • 介绍一下 Netty 的核心组件?

              • Bootstrap 和 ServerBootstrap 了解么?

              • NioEventLoopGroup 默认的构造函数会起多少线程?

              • Netty 线程模型了解么?

              • 什么是 TCP 粘包/拆包?有什么解决办法呢?

              • Netty 长连接、心跳机制了解么?

              (三)权限认证

              • 认证 (Authentication) 和授权 (Authorization)的区别是什么?

              • 什么是 Cookie ? Cookie 的作用是什么?如何在服务端使用 Cookie ?

              • Cookie 和 Session 有什么区别?如何使用 Session 进行身份验证?

              • 如果没有 Cookie 的话 Session 还能用吗?

              • 为什么 Cookie 无法防止 CSRF 攻击,而 token 可以?

              • 什么是 Token?什么是 JWT?如何基于 Token 进行身份验证?

              • 什么是 OAuth 2.0?

              • 什么是 SSO(单点登录)?

              七、系统设计

              (一)分布式理论

              • CAP & BASE 理论详解

              • Paxos 算法详解

              • Raft 算法详解

              (二)RPC


              RPC 基础

              • 了解 RPC 吗?有哪些常见的 RPC 框架?

              • 如果让你自己设计 RPC 框架你会如何设计?

              • 服务之间的调用为啥不直接用 HTTP 而用 RPC?

              Dubbo

              • Dubbo 了解吗?

              • Dubbo 的工作原理了解么?注册中心扮演了什么角色?注册中心挂了可以继续通信吗?

              • Dubbo 的负载均衡策略了解么?

              • Dubbo 的 spi 机制了解么?带来了啥好处?

              (四)分布式 ID

              • 何为 ID?

              • 何为分布式 ID?

              • 一个合格的分布式 ID 需要满足什么要求?

              • 分布式 ID 常见的生成方法有哪些?(数据库主键自增、数据库的号段模式、UUID、SNOWFLAKE 等等)

              (五)API 网关

              • 什么是网关?

              • 网关能提供哪些功能?

              • 有哪些常见的网关系统?

              (五)分布式锁

              基于 Redis 实现分布式锁

              • 如何基于 Redis 实现一个最简易的分布式锁?

              • 为什么要给锁设置一个过期时间?

              • 如何实现锁的优雅续期?

              • 如何实现可重入锁?

              • Redis 如何解决集群情况下分布式锁的可靠性?

              基于 ZooKeeper 实现分布式锁

              • 如何基于 ZooKeeper 实现分布式锁?

              • 为什么要用临时顺序节点?

              • 为什么要设置对前一个节点的监听?

              • 如何实现可重入锁?

              八、高并发

              (一)消息队列

              • 为什么要用消息队列?

              • 对比一下常见的消息队列?

              • 如何保证消息不被重复消费?

              • 如何保证消息消费的顺序性?

              (二)CDN(内容分发网络)

              • 什么是 CDN ?

              • CDN 的工作原理是什么?

              (三)读写分离和分库分表

              • 什么是读写分离?

              • 主库和从库的数据存在延迟的问题如何解决?

              • 如何实现读写分离?主从复制原理是什么?

              • 什么是分库?什么是分表?什么情况下需要分库分表?

              • 常见的分片算法有哪些?

              • 分库分表会带来什么问题呢?

              • 分库分表后,数据怎么迁移呢?

              九、系统设计/场景题

              • 假如有 10 亿个数,只有一个重复,内存只能放下 5 亿个数,怎么找到这个重复的数字?

              • 如何设计一个秒杀系统(服务端、数据库、分布式)?分布式系统的设计?

              • 有一个服务器专门接收大量请求,怎么设计?

              • 如果让你自己设计 RPC 框架你会如何设计?

              • 如何设计一个微博 Feed 流/信息流系统?

              • 如何设计一个短链系统?

              十、项目经历

              ……

              Java面经的评论 (共 条)

              分享到微博请遵守国家法律