75道阿里Java面试题,你能答上几道?
整理了下阿里近几年的java面试题目,大家参考下吧,希望对大家有帮助,可以帮大家查漏补缺。
答对以下这些面试题,可以淘汰掉 80 % 的求职竞争者。
1.hashcode相等两个类一定相等吗?equals呢?相反呢?
2.介绍一下集合框架?
3.hashmap hastable 底层实现什么区别?hashtable和concurrenthashtable呢?
4.hashmap和treemap什么区别?低层数据结构是什么?
5.线程池用过吗都有什么参数?底层如何实现的?
6.sychnized和lock什么区别?sychnize 什么情况情况是对象锁? 什么时候是全局锁为什么?
7.threadlocal 是什么底层如何实现?写一个例子呗?
8.volitile的工作原理?
9.cas知道吗如何实现的?
10.请用至少四种写法写一个单例模式?
11.请介绍一下jvm内存模型??用过什么垃圾回收器都说说呗
12.线上发送频繁full gc如何处理? cpu 使用率过高怎么办?
13.如何定位问题?如何解决说一下解决思路和处理方法
14.知道字节码吗?字节码都有哪些?integer x =5,int y =5,比较x =y 都经过哪些步骤?
15.讲讲类加载机制呗都有哪些类加载器,这些类加载器都加载哪些文件?
16.手写一下类加载demo
17.知道osgi吗? 他是如何实现的???
18.请问你做过哪些jvm优化?使用什么方法达到什么效果???
19.classforname("java.lang.string")和string classgetclassloader() loadclass("java.lang.string") 什么区别啊?
20.探查tomcat的运行机制即框架?
21.分析tomcat线程模型?
22.tomcat系统参数认识和调优?
23.mysql底层b+tree机制?
24.sql执行计划详解?
25.索引优化详解?
26.sql语句如如如何优化?
27.spring都有哪些机制啊aop底层如何实现的啊ioc呢??
28.cglib知道吗?他和jdk动态代理什么区别?手写一个jdk动态代理呗?
29.使用mysq1索引都有哪些原则? ?索引什么数据结构? 3+tree 和b tree 什么区别?
30.mysql有哪些存储引擎啊?都有啥区别? 要详细!
31.设计高并发系统数据库层面该怎么设计??数据库锁有哪些类型?如何实现呀?
32.数据库事务有哪些?
33.如何设计可以动态扩容缩容的分库分表方案?
34.用过哪些分库分表中间件,有啥优点和缺点?讲一下你了解的分库分表中间件的底层实现原理?
35.我现在有一个未分库分表的系统,以后系统需分库分表,如何设计,让未分库分表的系统动态切换到分库分表的系统上?tcc? 那若出现网络原因,网络连不通怎么办啊?
36.分布式事务知道吗? 你们怎么解决的?
37.为什么要分库分表啊?
38.rpc通信原理,分布式通信原理
39.分布式寻址方式都有哪些算法知道一致性hash吗?手写一下java实现代码??你若userid取摸分片,那我要查一段连续时间里的数据怎么办???
40.如何解决分库分表主键问题有什么实现方案??
41.redis和memcheched 什么区别为什么单线程的redis比多线程的memched效率要高啊?
42.redis有什么数据类型都在哪些场景下使用啊?
43.reids的主从复制是怎么实现的redis的集群模式是如何实现的呢redis的key是如何寻址的啊?
44.使用redis如何设计分布式锁?使用zk可以吗?如何实现啊这两种哪个效率更高啊??
45.知道redis的持久化吗都有什么缺点优点啊? ?具体底层实现呢?
46.redis过期策略都有哪些lru 写一下java版本的代码吧??
47.说一下dubbo的实现过程注册中心挂了可以继续通信吗??
48.dubbo支持哪些序列化协议?hessian 说一下hessian的数据结构pb知道吗为啥pb效率是最高的啊??
49.知道netty吗'netty可以干嘛呀nio,bio,aio 都是什么啊有什么区别啊?
50.dubbo复制均衡策略和高可用策略都有哪些啊动态代理策略呢?
51.为什么要进行系统拆分啊拆分不用dubbo可以吗'dubbo和thrift什么区别啊?
52.为什么使用消息队列啊消息队列有什么优点和缺点啊?
53.如何保证消息队列的高可用啊如何保证消息不被重复消费啊
54.kafka ,activemq,rabbitmq ,rocketmq都有什么优点,缺点啊???
55.如果让你写一个消息队列,该如何进行架构设计啊?说一下你的思路
56.说一下tcp 'ip四层?
57.的工作流程?? ?http1.0 http1.1http2.0 具体哪些区别啊?
58.tcp三次握手,四层分手的工作流程画一下流程图为什么不是四次五次或者二次啊?
59.画一下https的工作流程?具体如何实现啊?如何防止被抓包啊??
60.源码中所用到的经典设计思想及常用设计模式
61.系统架构如何选择合适日志技术(log4j、log4j2、slf4j、jcl…….)
62.springaop的原理,springaop和aspectj的关系,springaop的源码问题
63.dubbo框架的底层通信原理
64.rpc通信原理,分布式通信原理
65.如何利用springcloud来架构微服务项目
66.如何正确使用docker技术
67.springmvc的底层原理、如何从源码来分析其原理
68.mybaits的底层实现原理,如何从源码来分析mybaits
69.mysql的索引原理,索引是怎么实现的
70.索引的底层算法、如何正确使用、优化索引
71.springboot如何快速构建系统
72.zk原理知道吗zk都可以干什么paxos算法知道吗?说一下原理和实现?
73.如果让你写一个消息队列,该如何进行架构设计啊?说一下你的思路
74.分布式事务知道吗? 你们怎么解决的?
75.请问你做过哪些jvm优化?使用什么方法达到什么效果?