手记

【重点】Java大厂面试10个知识点汇总

本文收录在猪哥GitHub:github.com/pig6/Java 中,本项目收集一线大厂面试、实战、Java学习路线等。

本篇笔记是我五年来的工作学习面试经验&记录,希望对大家有一些帮助

一、java基础

  • Object类的所有方法:getClass hashCode equals clone toString notify notifyAll wait finalize
  • 八种基本数据类型&取值范围
  • 自动拆装箱&包装类型的缓存机制
  • ThreadLocal 理解String&不可变性 StringBuffer StringBuilder源码
  • ArrayList LinkedList HashMap(重点,可以花一天时间彻底掌握) LinkedHashMap TreeMap HashSet LinkedHashSet TreeSet源码
  • 异常体系结构
  • Java8:理解函数式编程 流式操作 CompletableFuture

二、并发编程

必考,高并发的解决必要手段,对于juc以及线程模型的演进过程的掌握非常重要

  • 理解并发与并行
  • 线程池的原理:理解每个参数
  • Thread Runnable Callable
  • AQS(重要:常常会配合synchronized来说) Condition
  • Lock:ReentrantLock ReentrantReadWriteLock
  • Semaphore CountDownLatch CyclicBarrier
  • 各种Atomic
  • ConcurrentHashMap BlockingQueue CopyOnWriteArrayList
  • Executors
  • 线程的状态转换:wait sleep notify notifyAll join park
  • 停止线程的方法
  • 线程模型:理解BIO、NIO(重点)、AIO、了解netty
  • 并发包就那些东西,掌握AQS之后其他的很快就打通了,所以不用

三、jvm

《深入理解java虚拟机》没事就看一遍,每次都会有新的理解

  • jvm内存结构
  • 常用调优参数
  • gc算法
  • gc的工具:CMS&G1重点&ZGC
  • java内存模型:
    • 可见性、原子性、顺序性、happens-before、内存屏障、volatile、final
    • synchronized(对象头):偏向锁->轻量级锁->重量级锁、monitor、锁优化、锁消除、锁粗化、自旋锁、可重入锁
  • 常用工具以及命令
  • 类加载过程
  • 对象创建过程
  • fullGC的排查思路
  • 工具:jps, jstack, jmap、jstat, jconsole, jinfo, jhat, javap, Arthas

四、设计模式

  • 创建型:单例模式、抽象工厂模式、建造者模式、工厂模式、原型模式。
  • 结构型模式:适配器模式、桥接模式、装饰模式、组合模式、外观模式、享元模式、代理模式。
  • 行为型模式:模版方法模式、命令模式、迭代器模式、观察者模式、中介者模式、备忘录模式、解释器模式(Interpreter模式)、状态模式、策略模式、职责链模式(责任链模式)、访问者模式。

五、mysql

下面列出来的全是重点

  • 常用sql以及内置函数
  • 索引
    • hash索引
    • b+树的索引
    • 聚集索引&非聚集索引
    • 回表
    • 联合索引:最左前缀&覆盖索引&索引下沉
  • 事务&隔离级别&实现原理:readview undolog redolog mvcc
  • 锁的使用&锁算法&行锁&表锁&乐观锁&悲观锁
  • 连接查询的原理(算法)
  • binlog&使用场景
  • 分库分表:垂直&水平
  • 工具:explain

六、redis

《redis的设计与实现》看完这本书就行了,深入浅出,很快就可以看完和掌握,直接搞定redis

  • 熟练五种类型对象&适用场景:字符串 列表 哈希 集合 有序集合
  • 了解底层数据结构:SDS 链表 字典 跳跃表 整数集合 压缩列表
  • 淘汰策略
  • RDB&AOF
  • 复制功能的实现
  • Sentinel&集群的结构
  • 发布订阅&事务
  • 分布式锁
  • 常见问题&解决方案:缓存击穿,缓存穿透,缓存雪崩

七、web

感觉很少有人问了,应届生可能问的多些

  • 三次握手与四次挥手
  • http/1.0 http/1.1 http/2之间的区别
  • http中 get和post区别
  • 理解https加密过程
  • forward&redirect的区别
  • CSRF&XSS攻击与防范
  • 常见的web请求返回的状态码
  • cookie&session
  • Servlet&filter&listener
  • DNS
  • tomcat&nginx区别

八、spring

说实话问到我的不多,感觉掌握下面几个足够了

  • IOC&DI&AOP
  • 掌握常用注解
  • 如何解决循环依赖
  • 事务传播机制
  • 事务失效场景
  • springMVC的理解
  • springboot的理解

九、分布式&高可用

平时多注意怎么处理好程序可能遇到的极端情况,保证服务的高可用

  • zookeeper
    • 理解使用:文件系统+监听器
    • 了解选举算法&分布式锁的实现
  • mq(重要,有时候面试官直接一串mq连环炮就可以决定要不要一个人了)
    • 作用:异步 解耦 削峰
    • kafka(之后会就kafka写一个系列)
      • 设计架构
      • 如何保证高可用
      • 如何保证高吞吐
      • 如何实现局部有序
      • 重复消费的问题
      • 延迟消息
  • 了解dubbo&spring cloud&Consul工作流程
  • 限流&熔断:Hystrix/Resilience4j(高可用的必须中间件)
  • 链路追踪(了解实现原理)

十、算法&数据结构

常刷leetcode

  • 栈、队列、链表、数组、哈希表、树、堆、图
  • 快排&二分&分治&递归&滑动窗口/双指针&BFS&DFS

十一、工具

  • git多分支协作流程
  • maven常用命令&生命周期
  • linux常用命令:tail grep awk sed等等

备注

  • 看着确实很绝望,up本人也是
  • 个人难免有盲区,欢迎评论区指正&补充,会持续更新
  • but
  • 种一棵树,最好的时间是十年前,其次是现在,大家共勉
码字不易,欢迎一键三连 关注猪哥!
0人推荐
随时随地看视频
慕课网APP