基础与框架:
1、String类能被继承吗,为什么
2、String,Stringbuffer,StringBuilder的区别?
3、ArrayList和LinkedList有什么区别
ArrayList内部是使用可増长数组实现的,所以是用get和set方法是花费常数时间的,但是如果插入元素和删除元素,除非 插入和删除的位置都在表末尾,否则代码开销会很大,因为里面需要数组的移动。
LinkedList是使用双链表实现的,所以get会非常消耗资源,除非位置离头部很近。但是插入和删除元素花费常数时间。类的实 例化顺序,比如父类静态数据,构造函数,字段,子类静态数据,构造函数,字段,他们的执行顺序
LinkedList是使用双链表实现的,所以get会非常消耗资源,除非位置离头部很近。但是插入和删除元素花费常数时间。类的实 例化顺序,比如父类静态数据,构造函数,字段,子类静态数据,构造函数,字段,他们的执行顺序
4、用过哪些Map,都有什么区别,HashMap是线程安全的吗,并发下使用的Map是什么,他们内部原理分别是什么,比如hashcode,扩容等
5、HashMap为什么get和set那么快,concurrentHashMap为什么能提高并发
6、抽象类和接口的区别,类可以继承多个类么,接口可以继承多个接口么,类可以实现多个接口么
7、什么情况下会发生栈内存溢出
8、什么是nio,原理
9、反射中,Class.forName和ClassLoader区别
10、tomcat结构,类加载器流程
11、讲讲Spring事务的传播属性,AOP原理,动态代理与cglib实现的区别,AOP有哪几种实现方式
12、Spring的beanFactory和factoryBean的区别
13、Spring加载流程
14、Spring如何管理事务的
多线程:
线城池的最大线程数目根据什么确定
多线程的几种实现方式,什么是线程安全,什么是重排序
volatile的原理,作用,能代替锁么
sleep和wait的区别,以及wait的实现原理
Lock与synchronized 的区别,synchronized 的原理,什么是自旋锁,偏向锁,轻量级锁,什么叫可重入锁,什么叫公平锁和非公平锁
用过哪些原子类,他们的参数以及原理是什么
用过哪些线程池,他们的原理简单概括下,构造函数的各个参数的含义,比如coreSize,maxsize等
有一个第三方接口,有很多个线程去调用获取数据,现在规定每秒钟最多有10个线程同时调用它,如何做到。
spring的controller是单例还是多例,怎么保证并发的安全
用三个线程按顺序循环打印abc三个字母,比如abcabcabc
ThreadLocal用过么,原理是什么,用的时候要注意什么
如果让你实现一个并发安全的链表,你会怎么做
JVM相关:
jvm中一次完整的GC流程(从ygc到fgc)是怎样的,重点讲讲对象如何晋升到老年代,几种主要的jvm参数等
你知道哪几种垃圾收集器,各自的优缺点,重点讲下cms
当出现了内存溢出,你怎么排错
JVM内存模型的相关知识了解多少
简单说说你了解的类加载器
JAVA的反射机制
网络:
http1.0和http1.1有什么区别
TCP三次握手和四次挥手的流程,为什么断开连接要4次,如果握手只有两次,会出现什么
TIME_WAIT和CLOSE_WAIT的区别
说说你知道的几种HTTP响应码
当你用浏览器打开一个链接的时候,计算机做了哪些工作步骤
Linux下IO模型有几种,各自的含义是什么
TCP/IP如何保证可靠性,数据包有哪些数据组成
架构设计与分布式:
tomcat如何调优,各种参数的意义
常见的缓存策略有哪些,你们项目中用到了什么缓存系统,如何设计的,Redis的使用要注意什么,持久化方式,内存设置,集群等
用java自己实现一个LRU
分布式集群下如何做到唯一序列号
设计一个秒杀系统,30分钟没付款就自动关闭交易
如何做一个分布式锁
用过哪些MQ,怎么用的,和其他mq比较有什么优缺点,MQ的连接是线程安全的吗
MQ系统的数据如何保证不丢失
分布式事务的原理,如何使用分布式事务
什么是一致性hash
什么是restful,讲讲你理解的restful
如何设计建立和保持100w的长连接?
解释什么是MESI协议(缓存一致性)
说说你知道的几种HASH算法,简单的也可以
什么是paxos算法
redis和memcached 的内存管理的区别
一个在线文档系统,文档可以被编辑,如何防止多人同时对同一份文档进行编辑更新
算法:
10亿个数字里里面找最小的10个
有1亿个数字,其中有2个是重复的,快速找到它,时间和空间要最优
2亿个随机生成的无序整数,找出中间大小的值
遍历二叉树
数据库:
数据库隔离级别有哪些,各自的含义是什么,MYsql默认的隔离级别是是什么,各个存储引擎优缺点
高并发下,如何做到安全的修改同一行数据,乐观锁和悲观锁是什么,INNODB的行级锁有哪2种,解释其含义
SQL优化的一般步骤是什么,怎么看执行计划,如何理解其中各个字段的含义,索引的原理?
数据库会死锁吗,举一个死锁的例子,mysql怎么解决死锁
MYsql的索引实现方式
聚集索引和非聚集索引的区别
数据库中 BTREE和B+tree区别
redis:
1、mySQL里有2000w数据,redis中只存20w的数据,如何保证redis中的数据都是热点数据
redis 内存数据集大小上升到一定大小的时候,就会施行数据淘汰策略。redis 提供 6种数据淘汰策略:
volatile-lru:从已设置过期时间的数据集(server.db[i].expires)中挑选最近最少使用的数据淘汰
volatile-ttl:从已设置过期时间的数据集(server.db[i].expires)中挑选将要过期的数据淘汰
volatile-random:从已设置过期时间的数据集(server.db[i].expires)中任意选择数据淘汰
allkeys-lru:从数据集(server.db[i].dict)中挑选最近最少使用的数据淘汰
allkeys-random:从数据集(server.db[i].dict)中任意选择数据淘汰
no-enviction(驱逐):禁止驱逐数据
2、redis为什么快?
1)完全基于内存存取的操作
2)采用I/O多路复用模型
3)单线程,都是原子操作,减少了线程之间的上下文切换和条件竞争
4)全程采用hash算法,和一些特殊算法
5)Redis采用自己实现的事件分离器,效率比较高,内部采用非阻塞的执行方式,吞吐能力比较大。