做为一个 Java 程序员,你平时老是陷在业务开发里,天天噼里啪啦忙敲着代码,上到系统开发,下到 Bug 修改,你感受本身无所不能。然而偶尔的一次聚会,你据说和本身一块儿出道的同窗早已经年薪 50 万,而本身却囊中羞涩。因而你也想看看新机会,找个新平台,好好发展。前端
可是面试的时候,当那个笑眯眯的面试官问出那些你再熟悉不过的 Java 问题时,你只是感受似曾相识,却怎么也回答不到点上。好比 HashMap 的工做原理,再或者 volatile 的使用场景。java
这个时候,你可能会怀疑本身的能力,也痛恨为何当初本身没有好好复习。node
该新版文档在Github上上传一个星期已经收获30K+star的Java核心面试神技(这参数,质量多高就不用我多说了吧)很是全面,包涵Java基础、Java集合、JavaWeb、Java异常、OOP、IO与NIO、反射、注解、多线程、JVM、MySQL、MongoDB、Spring全家桶、计算机网络、分布式架构、Redis、Linux、git、前端、算法与数据结构、MyBatis、RocketMQ、Netty、Dubbo、Zookeeper、分布式缓存、数据结构等等内容很是丰富,已经帮不少人拿下互联网一线公司的offer。下面我来跟你们一块儿分享一下。git
什么是B/S架构?什么是C/S架构程序员
Java都有哪些开发平台?面试
什么是JDK?什么是JRE?算法
Java语言有哪些特色sql
面向对象和面向过程的区别mongodb
什么是数据结构?数据库
Java的数据结构有哪些?
什么是OOP?
类与对象的关系?
Java中有几种数据类型
因为篇幅限制小编,pdf文档的详解资料太全面,细节内容实在太多啦,因此只把部分知识点截图出来粗略的介绍,每一个小节点里面都有更细化的内容!
有须要这份笔记完整版的朋友请添加VX(tkzl6666)获取。
ArrayList和linkedList的区别
HashMap和HashTable的区别
Collection包结构,与Collections的区别
泛型经常使用特色 (待补充)
说说List,Set,Map三者的区别
Array与ArrayList有什么不同?
Map有什么特色
集合内存放于 Java.util 包中, 主要有几 种接口
什么是list接口
说说ArrayList(数组)
因为文档里的细节内容实在过多因此只编辑了部分知识点的章节粗略的介绍下,每一个章节小节点里面都有更细化的内容!如下就是部分章节目录,因为篇幅限制目录上的详细讲解也没法一 一列出,文末底下有获取如下章节的全部详细知识讲解。
Java中异常分为哪两种?
异常的处理机制有几种?
如何自定义一个异常
try catch fifinally,try里有return,finally还执行么?
Excption与Error包结构
Thow与thorws区别
Error与Exception区别?
error和exception有什么区别
Java 中 IO 流?
Java IO与 NIO的区别
经常使用io类有哪些
字节流与字符流的区别
阻塞 IO 模型
非阻塞 IO 模型
多路复用 IO 模型
信号驱动 IO 模型
异步 IO 模型
JAVA NIO
除了使用new建立对象以外,还能够用什么方法建立对象?
Java反射建立对象效率高仍是经过new建立对象的效率高?
java反射的做用
哪里会用到反射机制?
反射的实现方式:
实现Java反射的类:
反射机制的优缺点:
Java 反射 API
反射使用步骤(获取 Class 对象、调用对象方法)
获取 Class 对象有几种方法
利用反射动态建立对象实例
什么是java序列化,如何实现java序列化?
保存(持久化)对象及其状态到内存或者磁盘
序列化对象以字节数组保持-静态成员不保存
序列化用户远程对象传输
Serializable 实现序列化
writeObject 和 readObject 自定义序列化策略
序列化 ID
序列化并不保存静态变量
Transient 关键字阻止该变量被序列化到文件中
序列化(深 clone 一中实现)
JAVA 并发知识库
Java中实现多线程有几种方法
继承 Thread 类
实现 Runnable 接口。
ExecutorService、 Callable、 Future 有返回值线程
基于线程池的方式
4 种线程池
如何中止一个正在运行的线程
notify()和notifyAll()有什么区别?
sleep()和wait() 有什么区别?
volatile 是什么?能够保证有序性吗?
java中会存在内存泄漏吗,请简单描述。
64 位 JVM 中,int 的长度是多数?
Serial 与 Parallel GC 之间的不一样之处?
32 位和 64 位的 JVM,int 类型变量的长度是多数?
Java 中 WeakReference 与 SoftReference 的区别?
JVM 选项 -XX:+UseCompressedOops 有什么做用?为何要使用
怎样经过 Java 程序来判断 JVM 是 32 位 仍是 64位?
32 位 JVM 和 64 位 JVM 的最大堆内存分别是多数?
JRE、JDK、JVM 及 JIT 之间有什么不一样?
解释 Java 堆空间及 GC?
数据库存储引擎
InnoDB(B+树)
TokuDB( Fractal Tree-节点带数据)
Memory
数据库引擎有哪些
InnoDB与MyISAM的区别
索引
常见索引原则有
数据库的三范式是什么
第一范式(1st NF - 列都是不可再分)
什么是 Redis?
Redis 与其余 key-value 存储有什么不一样?
Redis 的数据类型?
使用 Redis 有哪些好处?
Redis 相比 Memcached 有哪些优点?
Memcache 与 Redis 的区别都有哪些?
Redis 是单进程单线程的?
一个字符串类型的智能存储最大容量是多少?
Redis持久化机制
缓存雪崩、缓存穿透、缓存预热、缓存更新、缓存降级等问题
Memcached 是什么,有什么做用?
memcached 服务在企业集群架构中有哪些应用场景?
Memcached 服务分布式集群如何实现?
Memcached 服务特色及工做原理是什么?
简述 Memcached 内存管理机制原理?
memcached 是怎么工做的?
memcached 最大的优点是什么?
memcached 和 MySQL 的 query
memcached 和服务器的 local cache(好比 PHP 的 APC、mmap 文件等)相比,有什么优缺点?
memcached 的 cache 机制是怎样的?
memcached 如何实现冗余机制?
mongodb是什么?
mongodb有哪些特色?
你说的NoSQL数据库是什么意思?NoSQL与RDBMS直接有什么区别?为何要使用和不使用NoSQL数据库?说一说NoSQL数据库的几个优势?
NoSQL数据库有哪些类型?
MySQL与MongoDB之间最基本的差异是什么?
你怎么比较MongoDB、CouchDB及CouchBase?
MongoDB成为最好NoSQL数据库的缘由是什么?
journal回放在条目(entry)不完整时(好比恰巧有一个中途故障了)会遇到问题吗?
分析器在MongoDB中的做用是什么?
名字空间(namespace)是什么?
不一样版本的 Spring Framework 有哪些主要功能?
什么是 Spring Framework?
列举 Spring Framework 的优势。
Spring Framework 有哪些不一样的功能?
Spring Framework 中有多少个模块,它们分别是什么?
什么是 Spring 配置文件?
Spring 应用程序有哪些不一样组件?
使用 Spring 有哪些方式?
什么是 Spring IOC 容器?
什么是依赖注入?
什么是 Spring Boot?
为何要用SpringBoot
Spring Boot 有哪些优势?
Spring Boot 的核心注解是哪一个?它主要由哪几个注解组成的?
运行Spring Boot有哪几种方式
如何理解 Spring Boot 中的 Starters?
如何在Spring Boot启动的时候运行一些特定的代码?
Spring Boot 须要独立的容器运行吗?
Spring Boot中的监视器是什么?
如何使用Spring Boot实现异常处理?
什么是 Spring Cloud?
使用 Spring Cloud 有什么优点?
服务注册和发现是什么意思?Spring Cloud 如何实现?
负载平衡的意义什么?
什么是 Hystrix?它如何实现容错?
什么是 Hystrix 断路器?咱们须要它吗?
什么是 Netflix Feign?它的优势是什么?
什么是 Spring Cloud Bus?咱们须要它吗?
什么是微服务
什么是服务熔断?什么是服务降级
什么是 rabbitmq
为何要使用 rabbitmq
使用 rabbitmq 的场景
如何确保消息正确地发送至 RabbitMQ? 如何确保消息接收方消费了消息?
如何避免消息重复投递或重复消费?
消息基于什么传输?
消息如何分发?
消息怎么路由?
如何确保消息不丢失?
使用 RabbitMQ 有什么好处?
为何要用 Dubbo?
Dubbo 的总体架构设计有哪些分层?
默认使用的是什么通讯框架,还有别的选择吗?
服务调用是阻塞的吗?
通常使用什么注册中心?还有别的选择吗?
默认使用什么序列化框架,你知道的还有哪些?
服务提供者能实现失效提出是什么原理?
服务上线怎么不影响旧版本?
如何解决服务调用链过长的问题?
说说核心的配置有哪些?
什么是 Mybatis?
Mybaits 的优势
MyBatis 框架的缺点
MyBatis 框架适用场合
MyBatis 与 Hibernate 有哪些不一样?
{}和${}的区别是什么?
当实体类中的属性名和表中的字段名不同 ,怎么办 ?
模糊查询 like 语句该怎么写?
一般一个 Xml 映射文件,都会写一个 Dao 接口与之对应,请问,这个 Dao 接口的工做原理是什么?Dao 接口里的方法,参数不一样时,方法能重载吗?
如何获取自动生成的(主)键值?
什么是Zookeeper?
Zookeeper 如何保证了分布式一致性特性?
ZooKeeper 提供了什么?
Zookeeper 文件系统
ZAB 协议?
四种类型的数据节点 Znode
Zookeeper Watcher 机制 -- 数据变动通知
客户端注册 Watcher 实现
服务端处理 Watcher 实现
客户端回调 Watcher
栈(stack)
队列(queue)
链表(Link)
散列表(Hash Table)
排序二叉树
前缀树
红黑树
B-TREE
位图
elasticsearch 了解多少,说说大家公司 es 的集群架构,索引数据大小,分片有多少,以及一些调优手段 。
elasticsearch 的倒排索引是什么
elasticsearch 索引数据多了怎么办,如何调优,部署
elasticsearch 是如何实现 master 选举的
详细描述一下 Elasticsearch 索引文档的过程
详细描述一下 Elasticsearch 搜索的过程?
Elasticsearch 在部署时,对 Linux 的设置有哪些优化方法
lucence 内部结构是什么?
Elasticsearch 是如何实现 Master 选举的?
Elasticsearch 中的节点(好比共 20 个),其中的 10 个选了一个 master,另外 10 个选了另外一个 master,怎么办?
Kafka 是什么
partition 的数据文件(offset, MessageSize, data)
数据文件分段 segment(顺序读写、分段命令、二分查找)
负载均衡(partition 会均衡分布到不一样 broker 上)
批量发送
压缩(GZIP 或 Snappy)
消费者设计
Consumer Group
如何获取 topic 主题的列表
生产者和消费者的命令行是什么?
微服务架构有哪些优点?
微服务有哪些特色?
设计微服务的最佳时间是什么?
微服务架构如何运做?
微服务架构的优缺点是什么?
单片,SOA 和微服务架构有什么区别?
在使用微服务架构时,您面临哪些挑战?
SOA 和微服务架构之间的主要区别是什么?
微服务有什么特色?
绝对路径用什么符号表示?当前目录、上层目录用什么表示?主目录用什么表示? 切换目录用什么命令?
怎么查看当前进程?怎么执行退出?怎么查看当前路径?
怎么清屏?怎么退出当前命令?怎么执行睡眠?怎么查看当
Ls 命令执行什么功能? 能够带哪些参数,有什么区别?
查看文件有哪些命令
列举几个经常使用的Linux命令
你平时是怎么查看日志的?
创建软连接(快捷方式),以及硬连接的命令
目录建立用什么命令?建立文件用什么命令?复制文件用什么命令?
查看文件内容有哪些命令可使用?
面试,难仍是不难?最终结果好仍是很差?取决于面试者的底蕴(气场+技能)、心态和认知以及沟通技巧。而一些主流的大型互联网公司面试(阿里巴巴、京东、美团、滴滴)更是须要你在面试时展示出本身的能力,从而得到面试官的欣赏和确定。
而程序员在应聘时更是须要经历层层面试。俗话说,磨刀不误砍柴工,作好面试前的准备工做能够帮助你们更好的应对面试官的问题以及面试中的突发状况。
因为篇幅限制小编,pdf文档的详解资料太全面,细节内容实在太多啦,因此只把部分知识点截图出来粗略的介绍,每一个小节点里面都有更细化的内容!
须要这份神仙级Java面试笔记的朋友请添加VX(tkzl6666)免费获取。