java汇总
集合
- ArrayList 和 Vector 的区别
- 说说ArrayList,Vector,LinkedList的存储性能和特性
- 快速失败(fail-fast)和安全失败(fail-safe)的区别是什么?
- hashmap的数据结构
- HashMap的工作原理是什么?
- HashMap什么时候进行扩容呢?
- List,Map,Set三个接口,存取元素时,各有什么特点?
- Set里面的元素是不能重复的,那用什么方法区分重复与否呢?是用
==
还是equals()
? 它们有何区别? - head 和 stack有什么区别?
- 两个对象值相同(x.equals(y)==true),但却有不同的 hash code,这句话对不对?
- Java集合类框架的基本接口有哪些?
- HashSet和TreeSet有什么区别?
- HashSet底层实现是什么?
- LinkedHashMap的实现原理
- 为什么集合类没有实现Cloneable和Serializable接口?
- 什么是迭代器(iterator)?
- Iterator和ListIterator的区别是什么?
- 数组(Array)和列表(ArrayList)有什么区别?什么时候应该使用Array而不是ArrayList?
- Java结合类的框架的最佳实践有哪些?
- Set里的元素是不能重复的,那么用什么方法区分重复与否呢?是用
==
还是eauqls()
? 她们又何区别? - Comparable和Camparator接口是干什么的?列出它们的区别。
- Collection和Collections的区别
JVM与调优
- java类加载过程
- 描述一下JVM加载Class文件的原理机制
- Java内存分配
- GC是什么?为什么要有GC?
- 简述Java垃圾回收机制
- 如何判断一个对象是否存活(或者GC对象的判定方法)
- 垃圾回收的优点和原理,并考虑2种回收机制
- 垃圾回收器的基本原理是什么?垃圾回收器可以马上回收内存吗?有什么办法可以主动通知虚拟机进行垃圾回收?
- Java中会存在内存泄漏吗,请简单描述
- 深拷贝和浅拷贝
System.gc()
和Runtime.gc()
会做什么事情?finalize()
方法什么时候被调用?析构函数(finalization)的目的是什么?- 如果对象的引用被置为null,垃圾收集器是否会立即释放对象占用的内存?
- 什么是分布式垃圾回收(DGC)?它是如何工作的?
- 串行(serial)收集器和吞吐量(throughput)收集器的区别?
- 在java中,对象什么时候可以被垃圾回收
- 简述java内存分配与回收策略以及
Minor GC
和Major GC
- JVM的永久代会发生垃圾回收么?
- java中垃圾收集的方法有哪些?
- 什么是类加载器,类加载器有哪些?
- 类加载器双亲委派模型机制?
并发编程
- Synchronized 用过吗?其原理是什么?
- 你刚才提到捕获对象的‘锁’,这个锁是什么?如何确定对象的锁?
- 什么是可重入性, 为什么说
Synchronized
是可重入锁? - JVM对java的原生锁做了哪些优化?
- 为什么说
Synchronized
是非公平锁? - 什么是锁消除和锁粗化?
- 为什么说
Synchronized
是一个悲观锁?乐观锁的实现原理是什么?什么是CAS,它有什么特性? - 乐观锁一定就是好的吗?
- 跟
Synchronized
相比,可重入锁ReentrantLock
其实现原理有什么不同? - 那么请谈谈AQS框架是怎么回事儿?
- 请尽可能详细的对比下
Synchronized
和ReentrantLock
的异同? ReentrantLock
是如何实现可重入性的?- 除了
ReentrantLock
,你还接触过GUC的哪些开发工具? - 请谈谈
ReadWriteLock
和StampedLock
- 如何让java的线程彼此同步?你了解过哪些同步器?请分别介绍下
- CyclicBarrier和CountDownlatch看起来很相似,请对比下
- Java线程池相关问题
- Java中的线程池是如何实现的?
- 创建线程池的几个核心构造参数?
- 线程池中的线程是怎么创建的?是一开始就随着线程池的启动创建好的吗?
- 既然提到通过配置不同参数创建出不同的线程池,那么java中默认实现好的线程池又有哪些呢?请比较它们的异同
- 如何在java线程池中提交线程?
- 什么是java内存模型,java中各个线程是怎么彼此看到对方的变量的
- 请谈谈volatitle有什么特点,为什么它能保证变量对所有线程的可见性
- 既然volatitle能够保证线程间变量的可见性,是不是就意味着基于volatitle变量的运算就是并发安全的?
- 请对比下volatitle和Synchronized的异同
- 请谈谈ThreadLocal是怎么解决并发安全的
- 很多人都说要慎用Threadlocal,谈谈你的理解,使用ThreadLocal需要注意什么?
spring
- 什么是Spring框架?Spring框架主要有哪些模块?
- 使用Spring框架能带来哪些好处?
- 什么是控制反转(IOC)?什么是依赖注入?
- 请解释下Spring框架中的IOC
- BeanFactory和ApplicationContext有什么区别?
- Spring有几种配置方式
- 如何用基于xml配置方式的Spring?
- 如何用基于java配置配置方式配置Spring?
- 怎么用注解的方式配置Spring?
- 请解释Spring Bean的生命周期
- Spring Bean的作用域之间有什么区别
- 什么是Spring inner beans?
- 请举例说明如何在Spring中注入一个Java Collection?
- 如何向Sping Bean中注入一个java.util.Properties?
- 请解释Spring Bean的自动装配
- 请解释下自动装配模式的区别
- 如何开启基于注解的自动装配
- 请举例解释
@Required
注解 - 请举例解释
@Autowired
注解 - 请举例解释
@Qualifier
注解 - Spring框架中有哪些不同类型的事件
- 构造方法注入和设值注入的区别
- FileSystemResource 和 ClassPathResource 有何区别?
- Spring框架中都用到了哪些设计模式?
设计模式
- 请列举出在JDK中几个出几个常用的设计模式
- 什么是设计模式?你是否在你的代码里面使用过任何的设计模式
- java中什么叫单例设计模式?请用java写出线程安全的单例模式
- 在java中,什么叫观察者模式(observer design pattern)?
- 使用工厂模式最主要的好处是什么?在哪里使用?
- 举一个用java实现的装饰模式(decorator design pattern)? 它是作用于对象层次还是类层次?
- 在java中,为什么不允许从静态方法中访问非静态变量
- 设计一个ATM机,请说出你的设计思路
- 在java中,什么时候用重载,什么时候用重写?
- 举例说明什么情况下会更倾向于使用抽象类而不是接口
springboot
- 什么是Spring Boot?
- Spring Boot 有哪些优点?
- 什么是javaConfig?
- 如何重新加载Spring Boot上的更改,而无须重新启动服务器
- Spring Boot中的监视器是什么?
- 如何在Spring Boot中禁用Actuator端点安全性?
- 如何在自定义端口上运行Spring Boot应用程序
- 什么是YAML?
- 如何实现Spring Boot应用程序的安全性
- 如何继承Spring Boot和ActiveMQ?
- 如何使用Spring Boot实现分野和排序
- 什么是Swagger?你用Spring Boot实现了它吗?
- 什么是Spring Profiles
- 什么是Spring Batch?
- 什么是FreeMarker模板
- 如何使用用Spring Boot实现异常处理
- 您使用了哪些starter maven依赖项?
- 什么是CSRF攻击?
- 什么是WebSockts?
- 什么是AOP?
- 什么是Apache Kafka?
- 我们如何监视所有Spring Boot为服务?
Netty
- BIO, NIO, AIO的区别
- NIO的组成
- Netty的特点
- Netty的线程模型
- TCP粘包/拆包原理及解决方法?
- 了解哪几种序列化协议
- 如何选择序列化协议
- Netty的零拷贝实现
- Netty的高性能表现在哪些方面?
- NIOEventLoopGroup源码
Redis
- 什么是redis?
- redis特点
- redis支持的数据类型
- redis是单进程单线程的
- 虚拟内存
- Redis锁
- 读写分离模型
- 数据分片模型
- redis的回收策略
- 使用redis有哪些好处?
- redis相比memcached有哪些优势?
- redis常见性能问题和解决方案
- MYSQL里有2000w数据,redis中只有20w数据,如何保证redis中的数据都是热点数据
- memcache与redis的区别有哪些
- redis常见的性能问题都有哪些?如何解决
- redis最适合的场景
Redis