1篇文章全面总结2019年Java面试知识,掌握这些你也能进大厂!

前言

2019年还有不到2个月的时间就结束了,这一年你收获了没?你成长了没?改变了没?年初给本身定下的目标实现了没?java

这段时间小编整理了2019年目前为止的一些Java面试题资料资料,但愿能够和你们一块儿学习分享~node

这些Java面试题资料包括:Java基础、Java集合框架、JVM、Java多线程、MySQL、Redis、Spring、消息队列、Dubbo、算法、设计模式、数据库、网络协议、Linux系统、计算机原理等等相关知识点.,以及BATJ真实面试题,这些Java资料400页pdf文档,但愿这些资料对当你们有帮助!mysql

本文档提供详细的目录,你们能够根据本身的实际须要选择本身薄弱的知识参考阅读。程序员

Java 基础知识

  • 重载和重写的区别
  • String 和 StringBuffer、StringBuilder 的区别是什么?String 为何是不可变的?
  • 自动装箱与拆箱
  • Java 中的异常处理
  • 接口和抽象类的区别是什么
  • Object类的常见方法
  • 获取用键盘输入经常使用的的两种方法

Java基础知识的资料因为篇幅限制,就不一一举例了,欢迎你们关注个人公种浩【程序员追风】,文章都会在里面更新,整理的资料也会放在里面。面试

Java 集合框架

  • Arraylist 与 LinkedList 异同
  • ArrayList 与 Vector 区别
  • HashMap的底层实现
  • HashMap 和 Hashtable 的区别
  • HashMap 的长度为何是2的幂次方
  • HashMap 多线程操做致使死循环问题
  • HashSet 和 HashMap 区别
  • ConcurrentHashMap 和 Hashtable 的区别
  • ConcurrentHashMap线程安全的具体实现方式/底层具体实现
  • 集合框架底层数据结构

面试官在多线程这一部分极可能会问你有没有在项目中实际使用多线程的经历。因此,若是你在你的项目中有实际使用Java多线程的经历 的话,会为你加分很多哦!redis

Java多线程

  • 说一说本身对于 synchronized 关键字的了解
  • 说说本身是怎么使用 synchronized 关键字,在项目中用到了吗
  • 讲一下 synchronized 关键字的底层原理
  • 说说 JDK1.6 以后的synchronized 关键字底层作了哪些优化,能够详细介绍一下这些优化吗
  • 谈谈 synchronized和ReenTrantLock 的区别
  • 说说 synchronized 关键字和 volatile 关键字的区别
  • 为何要用线程池?
  • 实现Runnable接口和Callable接口的区别
  • 执行execute()方法和submit()方法的区别是什么呢?
  • 如何建立线程池
  • 介绍一下Atomic 原子类
  • JUC 包中的原子类是哪4类?
  • 讲讲 AtomicInteger 的使用
  • 能不能给我简单介绍一下 AtomicInteger 类的原理

Java多线程的知识因为篇幅限制,就不一一举例了,欢迎你们关注个人公种浩【程序员追风】,文章都会在里面更新,整理的资料也会放在里面。算法

JVM的设计目标是提供一个基于抽象规格描述的计算机模型,为解释程序开发人员提供很好的灵活性,同时也确保Java代码可在符合该规范的任何系统上运行。JVM对其实现的某些方面给出了具体的定义,特别是对Java可执行代码,即字节码(Bytecode)的格式给出了明确的规格。这一规格包括操做码和操做数的语法和数值、标识符的数值表示方式、以及Java类文件中的Java对象、常量缓冲池在JVM的存储映象。这些定义为JVM解释器开发人员提供了所需的信息和开发环境。Java的设计者但愿给开发人员以为所欲为使用Java的自由。spring

JVM

  • 内存模型以及分区,须要详细到每一个区放什么。
  • GC 收集器有哪些?CMS 收集器与 G1 收集器的特色。
  • Minor GC 与 Full GC 分别在何时发生?
  • 堆里面的分区:Eden,survival (from+ to),老年代,各自的特色。
  • 简述 java 垃圾回收机制?
  • java 中垃圾收集的方法有哪些?
  • 类加载器双亲委派模型机制?什么是类加载器,类加载器有哪些?
  • 简述 java 内存分配与回收策率以及 Minor GC 和Major GC

网络协议

  • TCP、UDP 协议的区别
  • 在浏览器中输入url地址 ->> 显示主页的过程
  • 各类协议与HTTP协议之间的关系
  • HTTP长链接、短链接
  • TCP 三次握手和四次挥手(面试常客)

网络协议的知识因为篇幅限制,就不一一举例了,欢迎你们关注个人公种浩【程序员追风】,文章都会在里面更新,整理的资料也会放在里面。sql

MySQL是一种关系数据库管理系统,关系数据库将数据保存在不一样的表中,而不是将全部数据放在一个大仓库内,这样就增长了速度并提升了灵活性。数据库

MySQL所使用的 SQL 语言是用于访问数据库的最经常使用标准化语言。MySQL 软件采用了双受权政策,分为社区版和商业版,因为其体积小、速度快、整体拥有成本低,尤为是开放源码这一特色,通常中小型网站的开发都选择 MySQL 做为网站数据库。

MySQL

  • Mysql 的技术特色是什么?
  • MYSQL 数据表在什么状况下容易损坏?
  • 说说本身对于 MySQL 常见的两种存储引擎:MyISAM与InnoDB的理解
  • 数据库索引了解吗?
  • 能说下MySQL 的基本存储结构吗?
  • Mysql如何为表字段添加索引?
  • 对于大表的常见优化手段说一下
  • mysql 里记录货币用什么字段类型好
  • 当MySQL单表记录数过大时,数据库的CRUD性能会明显降低,有哪些常见的优化措施?

简单来讲 redis 就是一个数据库,不过与传统数据库不一样的是 redis 的数据是存在内存中的,因此存写速度很是快,所以 redis 被普遍应用于缓存方向。另外,redis 也常常用来作分布式锁。redis 提供了多种数据类型来支持不一样的业务场景。除此以外,redis 支持事务 、持久化、LUA脚本、LRU驱动事件、多种集群方案。

Redis

  • 为何要用 redis /为何要用缓存?
  • 为何要用 redis 而不用 map/guava 作缓存?
  • redis 和 memcached 的区别?
  • 上述 Redis 分布式锁的缺点?
  • redis 常见数据结构以及使用场景分析
  • redis 内存淘汰机制(MySQL里有2000w数据,Redis中只存20w的数据,如何保证Redis中的数据都是热点数据?)
  • redis 持久化机制(怎么保证 redis 挂掉以后再重启数据能够进行恢复)?
  • 缓存雪崩和缓存穿透问题解决方案?
  • 如何解决 Redis 的并发竞争 Key 问题?
  • 如何保证缓存与数据库双写时的数据一致性?

Spring通常是不可避免的,若是你的简历上注明了你会Spring Boot或者Spring Cloud的话,那么面试官也可能会同时问你这两个技术,好比他可能会问你springboot和spring的区别。 因此,必定要谨慎对待写在简历上的东西,必定要对简历上的东西很是熟悉。

另外,AOP实现原理、动态代理和静态代理、Spring IOC的初始化过程、IOC原理、本身怎么实现一个IOC容器? 这些东西都是常常会被问到的。

Spring

  • Spring Bean 的做用域?
  • 如何用基于 Java 配置的方式配置 Spring?
  • 请说下 Spring Bean 的生命周期?
  • Spring Bean 的做用域之间有什么区别?
  • 请举例说明如何在 Spring 中注入一个 Java Collection?
  • Spring 框架中有哪些不一样类型的事件?
  • Spring 框架中都用到了哪些设计模式?
  • 开发中主要使用 Spring 的什么技术 ?

Spring的知识点因为篇幅限制,就不一一举例了,欢迎你们关注个人公种浩【程序员追风】,文章都会在里面更新,整理的资料也会放在里面。

“RabbitMQ?”“Kafka?”“RocketMQ?”...在平常学习与开发过程当中,咱们经常听到消息队列这个关键词。这也是面试常常被问到的

消息队列

  • 什么是消息队列?
  • 为何要用消息队列?丢消息怎么办?
  • 如何解决消息重复问题?
  • ActiveMQ 中的消息重发时间间隔和重发次数吗?
  • ActiveMQ 服务器宕机怎么办?
  • ActiveMQ 如何调优?
  • Basic.Reject 的用法是什么?
  • 为何不该该对全部的 message 都使用持久化机制?
  • 为何 heavy RPC 的使用场景下不建议采用 disk node ?

消息队列的知识因为篇幅限制,就不一一举例了,欢迎你们关注个人公种浩【程序员追风】,文章都会在里面更新,整理的资料也会放在里面。

Dubbo 是由阿里开源,后来加入了 Apache 。正式因为 Dubbo 的出现,才使得愈来愈多的公司开始使用以及接受分布式架构,因此面试时也是常常被问到的

Dubbo

  • 什么是 Dubbo?
  • 什么是 RPC?RPC原理是什么?
  • 为何要用 Dubbo?
  • 什么是分布式?为何要分布式?
  • 先来解释一下什么是负载均衡?
  • Dubbo 集群提供了哪些负载均衡策略?
  • Dubbo 支持哪些协议,每种协议的应用场景,优缺点?
  • Dubbo 的集群容错方案有哪些?
  • Dubbo 和 Spring Cloud 的关系?

数据结构比较常问的就是:二叉树、红黑树(极可能让你手绘一个红黑树出来哦!)、二叉查找树(BST)、平衡二叉树(Self-balancing binary search tree)、B-树,B+树与B*树的优缺点比较、 LSM 树这些知识点。

数据结构很重要,并且学起来也相对要难一些。建议学习数据结构必定要按部就班的来,一步一个脚印的走好。必定要搞懂原理,最好本身能用代码实现一遍。

数据结构

  • 什么是队列
  • 说下什么是队列的种类
  • 什么是 Set?说下HashSet 和 TreeSet 底层数据结构
  • 什么是List?List的常见实现类是什么?

在Linux操做系统中,全部被操做系统管理的资源,例如网络接口卡、磁盘驱动器、打印机、输入输出设备、普通文件或是目录都被看做是一个文件。

也就是说在LINUX系统中有一个重要的概念:一切都是文件。其实这是UNIX哲学的一个体现,而Linux是重写UNIX而来,因此这个概念也就传承了下来。在UNIX系统中,把一切资源都看做是文件,包括硬件设备。UNIX系统把每一个硬件都当作是一个文件,一般称为设备文件,这样用户就能够用读写文件的方式实现对硬件的访问。

Linux

  • 简单介绍一下 Linux 文件系统?
  • 一些常见的 Linux 命令了解吗?
  • Linux 中主要有哪几种内核锁?
  • Linux 中的用户模式和内核模式是什么含意?
  • 用户进程间通讯主要哪几种方式?
  • 经过伙伴系统申请内核内存的函数有哪些?
  • 模块程序可否使用可连接的库函数?
  • Linux 经过什么方式实现系统调用?
  • Linux 软中断和工做队列的做用是什么?

再强调几点:

  • 1. 必定要谨慎对待写在简历上的东西,必定要对简历上的东西很是熟悉。由于通常状况下,面试官都是会根据你的简从来问的; 能有一个上得了台面的项目也很是重要,这极可能是面试官会大量发问的地方,因此在面试以前好好回顾一下本身所作的项目;
  • 2. 和面试官聊基础知识好比设计模式的使用、多线程的使用等等,能够结合具体的项目场景或者是本身在平时是如何使用的;
  • 3. 注意本身开源的Github项目,面试官可能会挖你的Github项目提问;

愿各位Java工程师朋友们能始终不忘初心!每一个人都有每一个人的难处。引用一句《阿甘正传》里面的台词:“生活就像一盒巧克力,你永远不知道下一块是什么味道“。

另外,我我的以为面试也像是一场全新的征程,失败和胜利都是日常之事。因此,劝各位不要由于面试失败而灰心、丧失斗志。也不要由于面试经过而沾沾自喜,等待你的将是更美好的将来,继续加油!

因为篇幅限制小编,以上Java知识点所有整理在一个pdf文档里了,文档里的详解资料太全面,因此只把部分知识点截图出来粗略的介绍,每一个小节点里面都有更细化的内容!欢迎你们关注个人公种浩【程序员追风】,文章都会在里面更新,整理的资料也会放在里面。

性能调优系列

1.Comcat性能调优

JVM参数调优: -Xms<size> 表示JVM初始化堆的大小,一Xmx<size>表示JVM堆的最大值。这两个值的大小通常根据须要进行设置。当应用程序须要的内存超出堆的最大值时虚拟机就会提示内存溢出,而且致使应用服务崩溃。所以- -般建议堆的最大值设置为可用内存的最大值的80%。在catalina.bat中,设置JAVA _0PTS='-Xms256m-Xmx512m',表示初始化内存为256MB,可使用的最大内存512MB。

2.JVM性能调优

Java类加载过程 Java类加载须要经历一下7个过程: 1.加载 加载是类加载的第一个过程,在这个阶段,将完成一下三件事情 (1)经过一个类的全限定名获取该类的二进制流。 (2)将该二进制流中的静态存储结构转化为方法去运行时数据结构。 (3)在内存中生成该类的Class对象,做为该类的数据访问入口。

3.MySQL调优

微服务系列

什么是 Spring Cloud?

Spring cloud 流应用程序启动器是基于 Spring Boot 的 Spring 集成应用程序,提供与外部系统的集成。Spring cloud Task,一个生命周期短暂的微服务框架,用于快速构建执行有限数据处理的应用程序。

使用 Spring Cloud 有什么优点?

使用 Spring Boot 开发分布式微服务时,咱们面临如下问题

1.与分布式系统相关的复杂性-这种开销包括网络问题,延迟开销,带宽问题,安全问题。

2.服务发现-服务发现工具管理群集中的流程和服务如何查找和互相交谈。它涉及一个服务目录,在该

目录中注册服务,而后可以查找并链接到该目录中的服务。

3. 冗余-分布式系统中的冗余问题。

4. 负载平衡 --负载平衡改善跨多个计算资源的工做负荷,诸如计算机,计算机集群,网络链路,中央

处理单元,或磁盘驱动器的分布。

5.性能-问题 因为各类运营开销致使的性能问题。

6. 部署复杂性-Devops 技能的要求。

并发编程系列

Synchronized原理

synchronized和ReentrantLock的区别

synchronized是和if、else、for、while同样的关键字,ReentrantLock是类,这是两者的本质区别。既然ReentrantLock是类,那么它就提供了比synchronized更多更灵活的特性,能够被继承、能够有方法、能够有各类各样的类变量,ReentrantLock比synchronized的扩展性体如今几点上:

(1)ReentrantLock能够对获取锁的等待时间进行设置,这样就避免了死锁

(2)ReentrantLock能够获取各类锁的信息

(3)ReentrantLock能够灵活地实现多路通知

另外,两者的锁机制其实也是不同的。ReentrantLock底层调用的是Unsafe的park方法加锁,synchronized操做的应该是对象头中mark word,这点我不能肯定。

开源框架系列

1.spring面试

什么是 Spring 框架,Spring 框架有哪些主要模块

Spring 框架是一个为 Java 应用程序开发提供综合、普遍的基础性支持的 Java 平台。

Spring 帮助开发者解决了开发中基础性的问题,使得开发人员能够专一于应用程序的开发。

Spring 框架自己也是按照设计模式精心打造的,这使得咱们能够在开发环境中安心地集成

Spring 框架,没必要担忧 Spring 是如何在后台工做的。

什么是 SpringMvc?

SpringMvc 是 spring 的一个模块,基于 MVC 的一个框架,无需中间整合层来整合。

分布式专题

1.分布式限流面试

谈下你对 Zookeeper 的认识?

ZooKeeper 是一个分布式的,开放源码的分布式应用程序协调服务。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。

ZooKeeper 的目标就是封装好复杂易出错的关键服务,将简单易用的接口和性能高效、功能稳定的系统提供给用户。

Zookeeper 都有哪些功能?

1. 集群管理:监控节点存活状态、运行请求等;

2. 主节点选举:主节点挂掉了以后能够从备用的节点开始新一轮选主,主节点选举说的就是这个选举的过程,使用 Zookeeper 能够协助完成这个过程;

3. 分布式锁:Zookeeper 提供两种锁:独占锁、共享锁。独占锁即一次只能有一个线程使用资源,共享锁是读锁共享,读写互斥,便可以有多线线程同时读同一个资源,若是要使用写锁也只能有一个线程使用。Zookeeper 能够对分布式锁进行控制。

4. 命名服务:在分布式系统中,经过使用命名服务,客户端应用可以根据指定名字来获取资源或服务的地址,提供者等信息。

以上这些整理的Java资料共有400多页的pdf文档,文档里的详解资料太全面,因此只把部分知识点截图出来粗略的介绍,每一个小节点里面都有更细化的内容!欢迎你们关注个人公种浩【程序员追风】,文章都会在里面更新,整理的资料也会放在里面。

2019年还有不到2个月的时间就结束了,这一年你收获了没?你成长了没?改变了没?年初给本身定下的目标实现了没?

最后

整理资料不易,但愿这些Java资料的的Java工程师朋友们有帮助!喜欢文章记得点个赞哟,感谢支持!

相关文章
相关标签/搜索