2019年最新145道面试题整理(Java向)这些都会还不轻松入大厂!

面试题模块介绍

咱们这份面试题,包含的内容了十二个模块:Java 基础、Java IO、Java Web、JVM、开源框架、多线程、网络通讯、数据库MySql、设计模式、算法、并发与性能调优、其余等;java

可能对于初学者不须要看中间的框架和 JVM 模块的知识,读者朋友们可根据本身的状况,选择对应的模块进行阅读。linux

具体面试题

下面一块儿来看 145 道面试题,具体的内容。web

1、Java基础

  1. String类为何是final的
  2. HashMap的源码,实现原理,底层结构。
  3. 说说你知道的几个Java集合类:list、set、queue、map实现类。
  4. 描述一下ArrayList和LinkedList各自实现和区别
  5. Java中的队列都有哪些,有什么区别。
  6. 反射中,Class.forName和classloader的区别。
  7. Java七、Java8的新特性
  8. Java数组和链表两种结构的操做效率,在哪些状况下(从开头开始,从结尾开始,从中间开始),哪些操做(插入,查找,删除)的效率高。
  9. Java内存泄露的问题调查定位:jmap,jstack的使用等等。
  10. string、stringbuilder、stringbuffer区别
  11. hashtable和hashmap的区别
  12. 异常的结构,运行时异常和非运行时异常,各举个例子。
  13. String 类的经常使用方法
  14. Java 的引用类型有哪几种
  15. 抽象类和接口的区别
  16. java的基础类型和字节大小
  17. Hashtable,HashMap,ConcurrentHashMap底层实现原理与线程安全问题。
  18. 若是不让你用Java Jdk提供的工具,你本身实现一个Map,你怎么作。说了很久,说了HashMap源代码,若是我作,就会借鉴HashMap的原理,说了一通HashMap实现。
  19. Hash冲突怎么办?哪些解决散列冲突的方法?
  20. HashMap冲突很厉害,最差性能,你会怎么解决?从O(n)提高到log(n)。
  21. rehash
  22. hashCode() 与 equals() 生成算法、方法怎么重写。

2、Java IO

  1. 讲讲IO里面的常见类,字节流、字符流、接口、实现类、方法阻塞。
  2. 讲讲NIO
  3. String 编码UTF-8 和GBK的区别?
  4. 何时使用字节流、何时使用字符流?
  5. 递归读取文件夹下的文件,代码怎么实现?

3、Java Web

  1. session和cookie的区别和联系,session的生命周期,多个服务部署时session管理。
  2. jsp 和 servlet 有什么区别?
  3. jsp 有哪些内置对象?做用分别是什么?
  4. 说一下 jsp 的 4 种做用域?
  5. session 和 cookie 有什么区别?
  6. 说一下 session 的工做原理?
  7. 若是客户端禁止 cookie 能实现 session 还能用吗?
  8. spring mvc 和 struts 的区别是什么?
  9. 如何避免 sql 注入?
  10. 什么是 XSS 攻击,如何避免?
  11. 什么是 CSRF 攻击,如何避免?
  12. webservice相关问题
  13. jdbc链接,forname方式的步骤,怎么声明使用一个事务。
  14. 无框架下配置web.xml的主要配置内容
  15. jsp和servlet的区别

4、JVM

  1. Java的内存模型以及GC算法
  2. jvm性能调优都作了什么
  3. 介绍JVM中7个区域,而后把每一个区域可能形成内存的溢出的状况说明。
  4. 介绍GC 和GC Root不正常引用
  5. 本身从classload 加载方式,加载机制说开去,从程序运行时数据区,讲到内存分配,讲到String常量池,讲到JVM垃圾回收机制,算法,hotspot。
  6. jvm 如何分配直接内存, new 对象如何不分配在堆而是栈上,常量池解析。
  7. 数组多大放在JVM老年代
  8. 老年代中数组的访问方式
  9. GC 算法,永久代对象如何 GC , GC 有环怎么处理。
  10. 谁会被 GC ,何时 GC。
  11. 若是想不被 GC 怎么办
  12. 若是想在 GC 中生存 1 次怎么办

5、开源框架

  1. hibernate和ibatis的区别
  2. 讲讲mybatis的链接池
  3. spring框架中须要引用哪些jar包,以及这些jar包的用途
  4. springMVC的原理
  5. springMVC注解的意思
  6. spring中beanFactory和ApplicationContext的联系和区别
  7. spring注入的几种方式
  8. spring如何实现事物管理的
  9. springIOC
  10. spring AOP的原理
  11. hibernate中的1级和2级缓存的使用方式以及区别原理(Lazy-Load的理解)
  12. Hibernate的原理体系架构,五大核心接口,Hibernate对象的三种状态转换,事务管理。

6、多线程

  1. Java建立线程以后,直接调用start()方法和run()的区别
  2. 经常使用的线程池模式以及不一样线程池的使用场景
  3. newFixedThreadPool此种线程池若是线程数达到最大值后会怎么办,底层原理。
  4. 多线程之间通讯的同步问题,synchronized锁的是对象,衍伸出和synchronized相关不少的具体问题,例如同一个类不一样方法都有synchronized锁,一个对象是否能够同时访问。或者一个类的static构造方法加上synchronized以后的锁的影响。
  5. 了解可重入锁的含义,以及ReentrantLock 和synchronized的区别
  6. 同步的数据结构,例如concurrentHashMap的源码理解以及内部实现原理,为何他是同步的且效率高。
  7. atomicinteger和Volatile等线程安全操做的关键字的理解和使用
  8. 线程间通讯,wait和notify
  9. 定时线程的使用
  10. 场景:在一个主线程中,要求有大量(不少不少)子线程执行完以后,主线程才执行完成。多种方式,考虑效率。
  11. 进程和线程的区别
  12. 什么叫线程安全?
  13. 线程的几种状态
  14. 并发、同步的接口或方法
  15. HashMap 是否线程安全,为什么不安全。 ConcurrentHashMap,线程安全,为什么安全。底层实现是怎么样的。
  16. J.U.C下的常见类的使用。 ThreadPool的深刻考察; BlockingQueue的使用。(take,poll的区别,put,offer的区别);原子类的实现。
  17. 简单介绍下多线程的状况,从创建一个线程开始。而后怎么控制同步过程,多线程经常使用的方法和结构
  18. volatile的理解
  19. 实现多线程有几种方式,多线程同步怎么作,说说几个线程里经常使用的方法。

7、网络通讯

  1. http是无状态通讯,http的请求方式有哪些,能够本身定义新的请求方式么。
  2. socket通讯,以及长链接,分包,链接异常断开的处理。
  3. socket通讯模型的使用,AIO和NIO。
  4. socket框架netty的使用,以及NIO的实现原理,为何是异步非阻塞。
  5. 同步和异步,阻塞和非阻塞。
  6. OSI七层模型,包括TCP,IP的一些基本知识
  7. http中,get post的区别
  8. 说说http,tcp,udp之间关系和区别。
  9. 说说浏览器访问 www.taobao.com,经历了怎样的过程。
  10. HTTP协议、 HTTPS协议,SSL协议及完整交互过程;
  11. tcp的拥塞,快回传,ip的报文丢弃
  12. https处理的一个过程,对称加密和非对称加密
  13. head各个特色和区别
  14. 说说浏览器访问 www.taobap.com,经历了怎样的过程。

8、数据库MySql

  1. MySql的存储引擎的不一样
  2. 单个索引、联合索引、主键索引
  3. Mysql怎么分表,以及分表后若是想按条件分页查询怎么办
  4. 分表以后想让一个id多个表是自增的,效率实现
  5. MySql的主从实时备份同步的配置,以及原理(从库读主库的binlog),读写分离。
  6. 写SQL语句和SQL优化
  7. 索引的数据结构,B+树
  8. 事务的四个特性,以及各自的特色(原子、隔离)等等,项目怎么解决这些问题。
  9. 数据库的锁:行锁,表锁;乐观锁,悲观锁
  10. 数据库事务的几种粒度
  11. 关系型和非关系型数据库区别

9、设计模式

  1. 单例模式:饱汉、饿汉。以及饿汉中的延迟加载,双重检查。
  2. 工厂模式、装饰者模式、观察者模式。
  3. 工厂方法模式的优势(低耦合、高内聚,开放封闭原则)

10、算法

  1. 使用随机算法产生一个数,要求把1-1000W之间这些数所有生成。
  2. 两个有序数组的合并排序
  3. 一个数组的倒序
  4. 计算一个正整数的正平方根
  5. 说白了就是常见的那些查找、排序算法以及各自的时间复杂度。
  6. 二叉树的遍历算法
  7. DFS,BFS算法
  8. 比较重要的数据结构,如链表,队列,栈的基本理解及大体实现。
  9. 排序算法与时空复杂度(快排为何不稳定,为何你的项目还在用)
  10. 逆波兰计算器
  11. Hoffman 编码
  12. 查找树与红黑树

11、并发与性能调优

  1. 有个每秒钟5k个请求,查询手机号所属地的笔试题,如何设计算法?请求再多,好比5w,如何设计整个系统?
  2. 高并发状况下,咱们系统是如何支撑大量的请求的
  3. 集群如何同步会话状态
  4. 负载均衡的原理
  5. 若是有一个特别大的访问量,到数据库上,怎么作优化(DB设计,DBIO,SQL优化,Java优化)
  6. 若是出现大面积并发,在不增长服务器的基础上,如何解决服务器响应不及时问题“。
  7. 假如你的项目出现性能瓶颈了,你以为可能会是哪些方面,怎么解决问题。
  8. 如何查找 形成 性能瓶颈出现的位置,是哪一个位置照成性能瓶颈。
  9. 你的项目中使用过缓存机制吗?有没用用户非本地缓存

12、其余

  1. 经常使用的linux下的命令
  2. 什么是 java 序列化?什么状况下须要序列化?
  3. 动态代理是什么?有哪些应用?
  4. 怎么实现动态代理?
  5. throw 和 throws 的区别?
  6. final、finally、finalize 有什么区别?
  7. try-catch-finally 中哪一个部分能够省略?
  8. try-catch-finally 中,若是 catch 中 return 了,finally 还会执行吗?
  9. 为何要使用 hibernate?
  10. hibernate 中如何在控制台查看打印的 sql 语句?
  11. rabbitmq 中 vhost 的做用是什么?
  12. kafka 同时设置了 7 天和 10G 清除数据,到第五天的时候消息达到了 10G,这个时候 kafka 将如何处理?