高级java面试总结

先说下大概技术:dubbo,zookeeper,数据库,分布式,多线程,高并发,mq中间件,redis
 

 

 

Mq  :涉及重复消费的问题,网络中断导致数据丢失的问题。

 

 

解决:唯一标识,中间状态,持久化。
queue和topic区别
Dubbe
rpc框架对http socket封装。  底层是容器,把key value放进去。
我们用cat监控dubbo的调用,可以多传一个参traceId。底层改rpc封装动态代理方法代码。
 
数据库:
索引(b+树)   联合索引() 
聚集索引 非聚集索引 覆盖索引
行锁  表锁(索引行锁还是表锁)
innoDB数据存储引擎
分库分表方案 分库分表后如何查询: 参考这里
主从分离(代码实现:shadingJDBC,代理实现:mycat,atlas)优缺点
 
 
zookeeper:
应用场景,在项目中如何使用
zk分布式锁:回头把这个代码及原理补下,具体实现要清楚
 
分布式:
分布式事务:Atomikos强一致性解决方案,并不好,比较复杂的如TTC事务补偿机制,两段提交机制,3段提交机制(略懂)
分布式唯一id:通过redis产生,防止将来迁库
CAP原理,BASE理论
分布式session,

 

 

 

 
Redis:
数据类型  :8种,5种基础,3种新类型

有哪些场景,项目中都用到什么,如string,hashmap,zset(排行榜)

batemap签到场景

Redis持久化 RDB,AOF如何使用,优缺点,

 

 

哨兵,主从分离
redis cluster 集群化部署
如何搭一套高可用的缓存架构,
防止缓存穿透,缓存雪崩

 


设计模式:
常用设计模式:
单例模式,代理模式,工厂模式,建造者模式,模板模式,观察者模式,门面模式,策略模式
都在哪些场景用过。


Jvm  java虚拟机
jmm java内存模型
都有哪些块:堆、栈、方法区、本地方法区,类加载器,等9块
堆里按代区分:新生代,老年代,持久代
垃圾回收:如何回收,有哪些算法:复制算法,标记整理算法,标记清除算法
为什么新生代使用复制算法,老年代使用标记整理算法,各优缺点
垃圾回收器有哪些。
可达性算法:
什么可以作为根:涉及到什么时候回收。
 
多线程
线程之间的通信,如何通信,如何同步,
有哪些锁,
synchronized:偏量锁,轻量锁,重量锁
lock:重入锁
cas:无锁并发编程
volatile:为什么他可以实现可见性,与synchronized区别
servlet是否线程安全?
实现线程顺序执行?
volatile\synchronized\reetrantLock区别和底层实现原理?
countDownLatch和CyclicBarrier区别和应用场景实现方式等?
如何解决OOM/CPU100%等?
 

 


并发包:
并发包下容器:concurrentHashMap原理,hashMap原理,queue,atomic
 
并发架构
有能力画并发架构图
并发架构:
限流,异步化,缓存(多种缓存:redis缓存,jvm缓存,nginx缓存),

 

 

 

数据结构
B树,B+树,B-树,红黑树,二叉平衡树,二叉树

LinkedList,ArrayList,vector

HashMap,treeMap,HashTable
HashTree
遍历,中序遍历,前序遍历,后序遍历等,

时间复杂度(O(n),O(n次方),O(log2 n))

 

最后打个小广告,嘿嘿

公司接软件外包挣点外快,介绍项目费10%-20%提成,团队实力强大,提供专业软件公司资质和发票。

另外还承包各种广告业务,提成高哦。联系v:    15313152616

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值