常见Java面试知识汇总

持续更新中······
一、多线程

1.ThreadPoolExecutor

线程池实现原理、关键的方法的作用、常见的应用场景

线程池中的线程的状态,线程池中添加任务的具体处理,线程池中没有任务时线程是什么状态

参考:http://www.importnew.com/19011.html

https://www.jianshu.com/p/87bff5cc8d8c

2.ReentrantLock

可重入锁的实现机制,如何加锁、释放锁,如何做到可重入

CAS机制

如何实现互斥阻塞的,同关键字synchronized对比

尝试编码实现producer & consumer,关联多个condition实现灵活地线程同步

ReentrantReadWriteLock的具体使用

3.synchronized

实现同步的原理,wait/notify/notifyall的使用

4.ThreadLocal

什么是ThreadLocal,具体应用,使用ThreadLocal会有哪些风险

为什么会发生内存溢出,如何避免,为什么使用ThreadLocal的弱引用作为ThreadLocalMap的key

尝试使用ThreadLocal实现简单的数据库连接池

5.CountDownLatch/CyclicBarrier

使用方法,哪一个是可以重用的

尝试编写demo

参考:http://ifeve.com/concurrency-cyclicbarrier/

6.Java锁机制

锁类型,可重入、共享锁/排它锁、乐观锁/悲观锁

自旋锁,锁粗化/锁消除,偏向锁/轻量级锁/重量级锁

参考:https://blog.csdn.net/nalanmingdian/article/details/77800355

7.volatile

volatile变量在内存中的含义,jvm的具体机制是怎么样的

8.Semaphore
通过构造函数Semaphore(int , boolean)可以控制是否公平

如何使用,尝试解决哲学家进餐问题
9.多线程基础
callable和runnable,future
二、JVM

1.JVM内存结构

方法区/运行时常量池、程序计数器、Java虚拟机栈、本地方法栈、堆

2.JVM内存模型

含义、volatile、final、synchronized

happen-before、重排序
参考:https://www.jianshu.com/p/d3fda02d4cae
3.类加载机制

加载过程、双亲委托机制

class二进制数据加载->验证->准备->解析->初始化->使用->卸载

类加载器

加载过程中如何保证一个类只被加载一次

参考:http://www.importnew.com/22228.html

http://www.cnblogs.com/paddix/p/5268559.html

http://www.hollischuang.com/archives/199

4.垃圾回收

gc算法

垃圾收集器

如何调优,jvm参数配置

命令使用jps、jstat、jmap、jstack

三、数据库(MySQL)

1.MySQL查询的完整过程

预编译查询、jdbc查询过程描述

参考:https://www.cnblogs.com/micrari/p/7112781.html

2.表设计

字段设计

3.索引设计

B+树实现原理、MySQL索引的种类、如何设计表的索引,有什么注意的地方

什么时候会用到索引,什么时候索引会失效

4.读写分离

怎么配置

5.分库分表

常见的策略,如何考虑自适应扩容,全局主键ID生成

拆分后怎么办,程序怎么连接数据库,跨库join问题,跨库事务问题

中间件的选择

四、消息

流行的消息队列Kafka、RabbitMQ、ActiveMQ

尝试实现producer & consumer模型

五、缓存

1.分布式缓存设计和应用

2.Redis

几种数据类型、Redis集群

六、分布式

1.基本理论

CAP定理

BASE理论

两阶段提交

三阶段提交

Paxos算法

2.Zookeeper

实现原理,选举机制

具体应用,实现分布式锁

3.分布式数据一致性解决方案

使用消息队列MQ·····
4.分布式锁
redis
zookeeper

七、spring

1.spring框架

spring解决的问题,bean容器是怎么初始化的,bean的加载过程、生命周期

选择使用Spring框架的原因(Spring框架为企业级开发带来的好处有哪些)?

  • 非侵入式:支持基于POJO的编程模式,不强制性的要求实现Spring框架中的接口或继承Spring框架中的类。
  • IoC容器:IoC容器帮助应用程序管理对象以及对象之间的依赖关系,对象之间的依赖关系如果发生了改变只需要修改配置文件而不是修改代码,因为代码的修改可能意味着项目的重新构建和完整的回归测试。有了IoC容器,程序员再也不需要自己编写工厂、单例,这一点特别符合Spring的精神”不要重复的发明轮子”。
  • AOP(面向切面编程):将所有的横切关注功能封装到切面(aspect)中,通过配置的方式将横切关注功能动态添加到目标代码上,进一步实现了业务逻辑和系统服务之间的分离。另一方面,有了AOP程序员可以省去很多自己写代理类的工作。
  • MVC:Spring的MVC框架是非常优秀的,从各个方面都可以甩Struts 2几条街,为Web表示层提供了更好的解决方案。
  • 事务管理:Spring以宽广的胸怀接纳多种持久层技术,并且为其提供了声明式的事务管理,在不需要任何一行代码的情况下就能够完成事务管理。
  • 其他:选择Spring框架的原因还远不止于此,Spring为Java企业级开发提供了一站式选择,你可以在需要的时候使用它的部分和全部,更重要的是,你甚至可以在感觉不到Spring存在的情况下,在你的项目中使用Spring提供的各种优秀的功能。

2.IOC

3.AOP

4.事务

5.springMVC

处理请求的过程、源码解析

如何配置
八、mybatis
1.配置
2.初始化过程

3.查询过程

你可能感兴趣的:(常见Java面试知识汇总)