Java面试笔记(强烈推荐)

1字数 1325阅读 3680

        本文是我自己在秋招复习时的读书笔记,整理的知识点,也是为了防止忘记,尊重劳动成果,转载注明出处哦!如果你也喜欢,那就点个小心心,文末赞赏一杯豆奶吧,嘻嘻。 让我们共同成长吧……


第一部分:

目录

一、算法 

    剑指 Offer 题解

        目录根据原书第二版进行编排,代码和原书有所不同,尽量比原书更简洁。

    Leetcode 题解

        对题目做了一个大致分类,并对每种题型的解题思路做了总结。

    算法

        排序、并查集、栈和队列、红黑树、散列表。

二、操作系统 

    计算机操作系统

        进程管理、内存管理、设备管理、链接。

    Linux

        基本实现原理以及基本操作。

三、网络

    计算机网络

        物理层、链路层、网络层、运输层、应用层。

    HTTP

        方法、状态码、Cookie、缓存、连接管理、HTTPs、HTTP 2.0。

    Socket

        I/O 模型、I/O 多路复用。

四、面向对象

    设计模式

        实现了 Gof 的 23 种设计模式。

    面向对象思想

        三大原则(继承、封装、多态)、类图、设计原则。

五、数据库

    数据库系统原理

        事务、锁、隔离级别、MVCC、间隙锁、范式。

    SQL

        SQL 基本语法。

    Leetcode-Database 题解

        Leetcode 上数据库题目的解题记录。

    MySQL

        存储引擎、索引、查询优化、切分、复制。

    Redis

        五种数据类型、字典和跳跃表数据结构、使用场景、和 Memcache 的比较、淘汰策略、持久化、文件事件的 Reactor 模式、复制。

六、Java

    Java 基础

        不会涉及很多基本语法介绍,主要是一些实现原理以及关键特性。

    Java 容器

        源码分析:ArrayList、Vector、CopyOnWriteArrayList、LinkedList、HashMap、ConcurrentHashMap、LinkedHashMap、WeekHashMap。

    Java 并发

        线程使用方式、两种互斥同步方法、线程协作、JUC、线程安全、内存模型、锁优化。

    Java 虚拟机

        运行时数据区域、垃圾收集、类加载。

    Java I/O

        NIO 的原理以及实例。

七、系统设计 

    系统设计基础

        性能、伸缩性、扩展性、可用性、安全性

    分布式

        分布式锁、分布式事务、CAP、BASE、Paxos、Raft

    集群

        负载均衡、Session 管理

    攻击技术

        XSS、CSRF、SQL 注入、DDoS

    缓存

        缓存特征、缓存位置、缓存问题、数据分布、一致性哈希、LRU、CDN

    消息队列

        消息处理模型、使用场景、可靠性

八、工具 

    Git

        一些 Git 的使用和概念。

    Docker

        Docker 基本原理。

    正则表达式

        正则表达式基本语法。

    构建工具

        构建工具的基本概念、主流构建工具介绍。

九、编码实践 

    重构

        参考 重构 改善既有代码的设计。

    代码可读性

        参考 编写可读代码的艺术。

    代码风格规范

        Google 开源项目的代码风格规范。

        第一部分转自:https://github.com/sjsdfg/Interview-Notebook-PDF,对于java程序员面试来说,是个很好的整理思路的文章,强烈推荐。感谢楼主分享。


第二部分

目录

一、常用集合

        ArrayList/Vector

        LinkedList

        HashMap

        HashSet

        LinkedHashMap

二、Java 多线程

        多线程中的常见问题

        synchronized 关键字原理

        多线程的三大核心

        对锁的一些认知

        ReentrantLock 实现原理

        ConcurrentHashMap 的实现原理

        如何优雅的使用和理解线程池

        深入理解线程通信

        交替打印奇偶数

三、JVM

        Java 运行时内存划分

        类加载机制

        OOM 分析

        垃圾回收

        对象的创建与内存分配

        你应该知道的 volatile 关键字

四、分布式相关

        分布式限流

        基于 Redis 的分布式锁

        分布式缓存设计

        分布式 ID 生成器

五、常用框架\第三方组件

        Spring Bean 生命周期

        Spring AOP 的实现原理

        Guava 源码分析(Cache 原理)

六、架构设计

        秒杀系统设计

        秒杀架构实践

七、DB 相关

        MySQL 索引原理

        SQL 优化

        数据库水平垂直拆分

八、数据结构与算法

        红包算法

        二叉树层序遍历

        是否为快乐数字

        链表是否有环

        从一个数组中返回两个值相加等于目标值的下标

        一致性 Hash 算法

        限流算法

        三种方式反向打印单向链表

        合并两个排好序的链表

        两个栈实现队列

        动手实现一个 LRU cache

        链表排序

        数组右移 k 次

九、Netty 相关

        SpringBoot 整合长连接心跳机制

        从线程模型的角度看 Netty 为什么是高性能的?

十、附加技能

        TCP/IP 协议

        一个学渣的阿里之路


    第二部分转自:https://github.com/crossoverJie/JCSprout


完结……

推荐阅读更多精彩内容