一、List 和 Set 的区别html
二、HashSet 是如何保证不重复的redis
三、HashMap 是线程安全的吗,为何不是线程安全的(最好画图说明多线程环境下不安全)?算法
四、HashMap 的扩容过程数据库
五、HashMap 1.7 与 1.8 的 区别,说明 1.8 作了哪些优化,如何优化的?apache
1.7在极端状况下(保存多全部元素都hash到一个位置,时间复杂度退化为O(n))segmentfault
1.8将链式方式在元素大于8个的时候保存到红黑树中。设计模式
六、final finally finalizeapi
七、强引用 、软引用、 弱引用、虚引用数组
八、Java反射缓存
九、Arrays.sort 实现原理和 Collection.sort 实现原理
不管是Collections.sort方法或者是Arrays.sort方法,底层实现都是TimSort实现的,这是jdk1.7新增的,之前是归并排序。TimSort算法就是找到已经排好序数据的子序列,而后对剩余部分排序,而后合并起来
十、LinkedHashMap的应用
十一、cloneable接口实现原理
若是一个类重写了 Object 内定义的 clone() ,须要同时实现 Cloneable 接口(虽然这个接口内并无定义 clone() 方法),不然在调用 clone() 时会报 CloneNotSupportedException 异常,也就是说, Cloneable 接口只是个合法调用 clone() 的标识(marker-interface)。
事实上,若想实现对象的克隆,你不得不重写 Object 的 clone() 方法,还得实现 Cloneable 接口,这样就有点麻烦了。
简单的作法,借助 Apache Commons 能够直接实现:
简单的克隆,也能够经过 copy-constructor (拷贝构造方法) 实现,详情参考 Effective Java 做者 Josh Bloch 的这篇访谈:Copy Constructor Versus Cloning
其中也谈到了 Cloneable 接口的不少缺点。
Cloneable 自己就是个比较鸡肋的接口,尽可能避免使用。
十二、异常分类以及处理机制
1三、wait和sleep的区别
1四、数组在内存中如何分配
一、synchronized 的实现原理以及锁优化?
二、volatile 的实现原理?
三、Java 的信号灯?
四、synchronized 在静态方法和普通方法的区别?
五、怎么实现全部线程在等待某个事件的发生才会去执行?
六、CAS?CAS 有什么缺陷,如何解决?
七、synchronized 和 lock 有什么区别?
八、Hashtable 是怎么加锁的 ?
九、HashMap 的并发问题?
十、ConcurrenHashMap 介绍?1.8 中为何要用红黑树?
十一、并发包中 A*S (*为键盘上O👉那个字母,傻B系统)
十二、如何检测死锁?怎么预防死锁?
将线程的等待资源保存成图,看是否是有环图
http://blog.csdn.net/ls5718/article/details/51896159
1三、Java 内存模型?
1四、如何保证多线程下 i++ 结果正确?
1五、线程池的种类,区别和使用场景?
1六、分析线程池的实现原理和线程的调度过程?
1七、线程池如何调优,最大数目如何确认??
1八、ThreadLocal原理,用的时候须要注意什么?
1九、CountDownLatch 和 CyclicBarrier 的用法,以及相互之间的差异?
20、LockSupport工具??
https://segmentfault.com/a/1190000008420938
2一、Condition接口及其实现原理??
2二、Fork/Join框架的理解??
2三、分段锁的原理,锁力度减少的思考
2四、八种阻塞队列以及各个阻塞队列的特性??
一、BeanFactory 和 FactoryBean?
二、Spring IOC 的理解,其初始化过程?
三、BeanFactory 和 ApplicationContext?
四、Spring Bean 的生命周期,如何被管理的?
五、Spring Bean 的加载过程是怎样的?
六、若是要你实现Spring AOP,请问怎么实现?
七、若是要你实现Spring IOC,你会注意哪些问题?
八、Spring 是如何管理事务的,事务管理机制?
九、Spring 的不一样事务传播行为有哪些,干什么用的?
十、Spring 中用到了那些设计模式?
十一、Spring MVC 的工做原理?
十二、Spring 循环注入的原理?
1三、Spring AOP的理解,各个术语,他们是怎么相互工做的?
1四、Spring 如何保证 Controller 并发的安全?
一、BIO、NIO和AIO
二、Netty 的各大组件
三、Netty的线程模型
四、TCP 粘包/拆包的缘由及解决方法
五、了解哪几种序列化协议?包括使用场景和如何去选择
六、Netty的零拷贝实现
七、Netty的高性能表如今哪些方面
一、Dubbo的底层实现原理和机制
二、描述一个服务从发布到被消费的详细过程
三、分布式系统怎么作服务治理
四、接口的幂等性的概念
幂等接口的内部实现须要有对内保护机制, 通常状况是用相似于乐观锁的版本机制.版本重点是体现时间的前后.
或者将非等幂操做转化成等幂实现如:
当用户点击赞同时,将答案的赞同数量+1。
改成:
当用户点击赞同时,确保答案赞同表中存在一条记录,用户、答案。
赞同数量由答案赞同表统计出来。
五、消息中间件如何解决消息丢失问题
六、Dubbo的服务请求失败怎么处理
七、重连机制会不会形成错误
八、对分布式事务的理解
九、如何实现负载均衡,有哪些算法能够实现?
十、Zookeeper的用途,选举的原理是什么?
十一、数据的垂直拆分水平拆分。
十二、zookeeper原理和适用场景
1三、zookeeper watch机制
1四、redis/zk节点宕机如何处理
1五、分布式集群下如何作到惟一序列号
1六、如何作一个分布式锁
1七、用过哪些队列,怎么用的,和其余队列比较有什么优缺点,队列的链接是线程安全的吗
1八、队列系统的数据如何保证不丢失
1九、列举出你能想到的数据库分库分表策略;分库分表后,如何解决全表查询的问题
20、zookeeper的选举策略
2一、全局ID
一、mys*l分页有什么优化
二、悲观锁、乐观锁
三、组合索引,最左原则
四、mys*l 的表锁、行锁
五、mys*l 性能优化
六、mys*l的索引分类:B+,hash;什么状况用什么索引
七、事务的特性和隔离级别
一、Redis用过哪些数据数据,以及Redis底层怎么实现
二、Redis缓存穿透,缓存雪崩
三、如何使用Redis来实现分布式锁
四、Redis的并发竞争问题如何解决??
五、Redis持久化的几种方式,优缺点是什么,怎么实现的
六、Redis的缓存失效策略
七、Redis集群,高可用,原理
八、Redis缓存分片??
九、Redis的数据淘汰策略
一、详细jvm内存模型
二、讲讲什么状况下回出现内存溢出,内存泄漏?
三、说说Java线程栈
四、JVM 年轻代到年老代的晋升过程的判断条件是什么呢?
五、JVM 出现 full GC 很频繁,怎么去线上排查问题?
六、类加载为何要使用双亲委派模式,有没有什么场景是打破了这个模式?
七、类的实例化顺序
八、JVM垃圾回收机制,什么时候触发MinorGC等操做
九、JVM 中一次完整的 GC 流程(从 ygc 到 fgc)是怎样的
十、各类回收器,各自优缺点,重点CMS、G1
十一、各类回收算法
十二、OOM错误,stackoverflow错误,permgen space错误
---------------------------
单机上一个线程池正在处理服务,若是突然断电了怎么办(正在处理和阻塞队列里的请求怎么处理)?
为何要使用线程池?
线程池有什么做用?
说说几种常见的线程池及使用场景。
线程池都有哪几种工做队列?
怎么理解无界队列和有界队列?
线程池中的几种重要的参数及流程说明。
说一下对jvm的理解,jvm的组成部分,各个部分的存储内容以及常见的jvm的问题排查步骤。
对JVM熟不熟悉?简单说说类加载过程,里面执行的那些操做?
JVM方法区存储内容 是否会动态扩展 是否会出现内存溢出 出现的缘由有哪些。
介绍介绍CMS。
介绍介绍G1。
为何jdk8用metaspace数据结构用来替代perm?
简单谈谈堆外内存以及你的理解和认识。
JVM的内存模型的理解,threadlocal使用场景及注意事项?
JVM老年代和新生代的比例?
jstack,jmap,jutil分别的意义?如何线上排查JVM的相关问题?
Java虚拟机中,数据类型能够分为哪几类?
怎么理解栈、堆?堆中存什么?栈中存什么?
为何要把堆和栈区分出来呢?栈中不是也能够存储数据吗?
在Java中,什么是是栈的起始点,同是也是程序的起始点?
为何不把基本类型放堆中呢?
Java中的参数传递时传值呢?仍是传引用?
Java中有没有指针的概念?
Java中,栈的大小经过什么参数来设置?
一个空Object对象的占多大空间?
对象引用类型分为哪几类?
讲一讲垃圾回收算法。
如何解决内存碎片的问题?
如何解决同时存在的对象建立和对象回收问题?
讲一讲内存分代及生命周期。
什么状况下触发垃圾回收?
如何选择合适的垃圾收集算法?
JVM中最大堆大小有没有限制?
堆大小经过什么参数设置?
JVM有哪三种垃圾回收器?
吞吐量优先选择什么垃圾回收器?响应时间优先呢?
如何进行JVM调优?有哪些方法?
如何理解内存泄漏问题?有哪些状况会致使内存泄露?如何解决?