几个大厂的面试题目目录:

*
java基础(40题)

*
多线程(51题)

*
设计模式(8点)

*
JVM(12题)

*
数据结构与算法(17题)

*
数据库(22题)

*
Spring (13题)

*
Netty(7大题)

*
缓存(9题)

*
技术框架(8题)

*
技术深度(12题)

*
分布式(33题)

*
系统架构(18题)

*
linux(9大题)

*
TCP/IP(19点)

*
软能力(12点)

面试题目答案,请看文章结尾,希望可以帮助大家,助你上位

java 基础

*
八种基本数据类型的大小,以及他们的封装类

*
引用数据类型

*
Switch能否用string做参数

*
equals与==的区别

*
自动装箱,常量池

*
Object有哪些公用方法

*
Java的四种引用,强弱软虚,用到的场景

*
Hashcode的作用

*
HashMap的hashcode的作用

*
为什么重载hashCode方法?

*
ArrayList、LinkedList、Vector的区别

*
String、StringBuffer与StringBuilder的区别

*
Map、Set、List、Queue、Stack的特点与用法

*
HashMap和HashTable的区别

*
JDK7与JDK8中HashMap的实现

*
HashMap和ConcurrentHashMap的区别,HashMap的底层源码

*
ConcurrentHashMap能完全替代HashTable吗

*
为什么HashMap是线程不安全的

*
如何线程安全的使用HashMap

*
多并发情况下HashMap是否还会产生死循环

*
TreeMap、HashMap、LindedHashMap的区别

*
Collection包结构,与Collections的区别

*
try?catch?finally,try里有return,finally还执行么

*
Excption与Error包结构,OOM你遇到过哪些情况,SOF你遇到过哪些情况

*
Java(OOP)面向对象的三个特征与含义

*
Override和Overload的含义去区别

*
Interface与abstract类的区别

*
Static?class?与non?static?class的区别

*
java多态的实现原理

*
foreach与正常for循环效率对比

*
Java?IO与NIO

*
java反射的作用于原理

*
泛型常用特点

*
解析XML的几种方式的原理与特点:DOM、SAX

*
Java1.7与1.8,1.9,10 新特性

*
设计模式:单例、工厂、适配器、责任链、观察者等等

*
JNI的使用

*
AOP是什么

*
OOP是什么

*
AOP与OOP的区别

多线程

*
什么是线程?

*
什么是线程安全和线程不安全?

*
什么是自旋锁?

*
什么是Java内存模型?

*
什么是CAS?

*
什么是乐观锁和悲观锁?

*
什么是AQS?

*
什么是原子操作?在Java Concurrency API中有哪些原子类(atomic classes)?

*
什么是Executors框架?

*
什么是阻塞队列?如何使用阻塞队列来实现生产者-消费者模型?

*
什么是Callable和Future?

*
什么是FutureTask?

*
什么是同步容器和并发容器的实现?

*
什么是多线程?优缺点?

*
什么是多线程的上下文切换?

*
ThreadLocal的设计理念与作用?

*
ThreadPool(线程池)用法与优势?

*
Concurrent包里的其他东西:ArrayBlockingQueue、CountDownLatch等等。

*
synchronized和ReentrantLock的区别?

*
Semaphore有什么作用?

*
Java Concurrency API中的Lock接口(Lock interface)是什么?对比同步它有什么优势?

*
Hashtable的size()方法中明明只有一条语句”return count”,为什么还要做同步?

*
ConcurrentHashMap的并发度是什么?

*
ReentrantReadWriteLock读写锁的使用?

*
CyclicBarrier和CountDownLatch的用法及区别?

*
LockSupport工具?

*
Condition接口及其实现原理?

*
Fork/Join框架的理解?

*
wait()和sleep()的区别?

*
线程的五个状态(五种状态,创建、就绪、运行、阻塞和死亡)?

*
start()方法和run()方法的区别?

*
Runnable接口和Callable接口的区别?

*
volatile关键字的作用?

*
Java中如何获取到线程dump文件?

*
线程和进程有什么区别?

*
线程实现的方式有几种(四种)?

*
高并发、任务执行时间短的业务怎样使用线程池?并发不高、任务执行时间长的业务怎样使用线程池?并发高、业务执行时间长的业务怎样使用线程池?

*
如果你提交任务时,线程池队列已满,这时会发生什么?

*
锁的等级:方法锁、对象锁、类锁?

*
如果同步块内的线程抛出异常会发生什么?

*
并发编程(concurrency)并行编程(parallellism)有什么区别?

*
如何保证多线程下 i++ 结果正确?

*
一个线程如果出现了运行时异常会怎么样?

*
如何在两个线程之间共享数据?

*
生产者消费者模型的作用是什么?

*
怎么唤醒一个阻塞的线程?

*
Java中用到的线程调度算法是什么

*
单例模式的线程安全性?

*
线程类的构造方法、静态块是被哪个线程调用的?

*
同步方法和同步块,哪个是更好的选择?

*
如何检测死锁?怎么预防死锁?

设计模式

*
装饰器模式

*
工厂模式

*
单例模式

*
观察者模式

*
动态代理模式

*
适配器模式

*
模板模式

*
策略模式



JVM

*
内存模型以及分区,需要详细到每个区放什么。

*
对象创建方法,对象的内存分配,对象的访问定位。

*
GC的两种判定方法:引用计数与引用链。

*
GC的三种收集方法:标记清除、标记整理、复制算法的原理与特点,分别用在什么地方,如果让你优化收集方法,有什么思路?

*
GC收集器有哪些?CMS收集器与G1收集器的特点。

*
Minor?GC与Full?GC分别在什么时候发生?

*
几种常用的内存调试工具:jmap、jstack、jconsole。

*
类加载的五个过程:加载、验证、准备、解析、初始化。

*
双亲委派模型:Bootstrap?ClassLoader、Extension?ClassLoader、ApplicationClassLoader。

*
分派:静态分派与动态分派。

*
JVM过去过来就问了这么些问题,没怎么变,内存模型和GC算法这块问得比较多,可以在网上多找几篇博客来看看。

*
推荐书籍:《深入理解java虚拟机》

数据结构与算法

*
链表与数组。

*
队列和栈,出栈与入栈。

*
链表的删除、插入、反向。

*
字符串操作。

*
Hash表的hash函数,冲突解决方法有哪些。

*
各种排序:冒泡、选择、插入、希尔、归并、快排、堆排、桶排、基数的原理、平均时间复杂度、最坏时间复杂度、空间复杂度、是否稳定。

*
快排的partition函数与归并的Merge函数。

*
对冒泡与快排的改进。

*
二分查找,与变种二分查找。

*
二叉树、B+树、AVL树、红黑树、哈夫曼树。

*
二叉树的前中后续遍历:递归与非递归写法,层序遍历算法。

*
图的BFS与DFS算法,最小生成树prim算法与最短路径Dijkstra算法。

*
KMP算法。

*
排列组合问题。

*
动态规划、贪心算法、分治算法。(一般不会问到)

*
大数据处理:类似10亿条数据找出最大的1000个数.........等等

*

算法的话其实是个重点,因为最后都是要你写代码,所以算法还是需要花不少时间准备,这里有太多算法题,写不全,我的建议是没事多在OJ上刷刷题(牛客网、leetcode等),剑指offer上的算法要能理解并自己写出来,编程之美也推荐看一看

数据库

*
事务四大特性(ACID)原子性、一致性、隔离性、持久性

*
数据库隔离级别,每个级别会引发什么问题,mysql默认是哪个级别

*
innodb和myisam存储引擎的区别

*
MYSQL的两种存储引擎区别(事务、锁级别等等),各自的适用场景

*
查询语句不同元素(where、jion、limit、group by、having等等)执行先后顺序

*
数据库的优化(从sql语句优化和索引两个部分回答)

*
索引有B+索引和hash索引,各自的区别

*
B+索引数据结构,和B树的区别

*
索引的分类(主键索引、唯一索引),最左前缀原则,哪些情况索引会失效

*
聚集索引和非聚集索引区别。

*
有哪些锁(乐观锁悲观锁),select时怎么加排它锁

*
关系型数据库和非关系型数据库区别

*
数据库三范式,根据某个场景设计数据表(可以通过手绘ER图)

*
数据库的读写分离、主从复制

*
使用explain优化sql和索引

*
long_query怎么解决

*
内连接、外连接、交叉连接、笛卡儿积等

*
死锁判定原理和具体场景,死锁怎么解决

*
varchar和char的使用场景。

*
mysql并发情况下怎么解决(通过事务、隔离级别、锁)

*
数据库崩溃时事务的恢复机制(REDO日志和UNDO日志)

*
查询语句不同元素(where、jion、limit、group by、having等等)执行先后顺序

Spring

*
IOC和DI是什么?

*
Spring IOC 的理解,其初始化过程?

*
BeanFactory 和 FactoryBean的区别?

*
BeanFactory和ApplicationContext的区别?

*
ApplicationContext 上下文的生命周期?

*
Spring Bean 的生命周期?

*
Spring AOP的实现原理?

*
Spring 是如何管理事务的,事务管理机制?

*
Spring 的不同事务传播行为有哪些,干什么用的?

*
Spring 中用到了那些设计模式?

*
Spring MVC 的工作原理?

*
Spring如何解决循环依赖?

*
Spring 如何保证 Controller 并发的安全?

Netty

*
BIO、NIO和AIO

*
Netty 的各大组件

*
Netty的线程模型

*
TCP 粘包/拆包的原因及解决方法

*
了解哪几种序列化协议?包括使用场景和如何去选择

*
Netty的零拷贝实现

*
Netty的高性能表现在哪些方面

缓存

*
Redis用过哪些数据数据,以及Redis底层怎么实现

*
Redis缓存穿透,缓存雪崩

*
如何使用Redis来实现分布式锁

*
Redis的并发竞争问题如何解决

*
Redis持久化的几种方式,优缺点是什么,怎么实现的

*
Redis的缓存失效策略

*
Redis集群,高可用,原理

*
Redis缓存分片

*
Redis的数据淘汰策略



技术框架

*
看过哪些开源框架的源码

*
为什么要用Redis,Redis有哪些优缺点?Redis如何实现扩容?

*
Netty是如何使用线程池的,为什么这么使用

*
为什么要使用Spring,Spring的优缺点有哪些

*
Spring的IOC容器初始化流程

*
Spring的IOC容器实现原理,为什么可以通过byName和ByType找到Bean

*
Spring AOP实现原理

*
消息中间件是如何实现的,技术难点有哪些

技术深度

*
事务的实现原理

*
有没有看过JDK源码,看过的类实现原理是什么。

*
HTTP协议

*
TCP协议

*
一致性Hash算法

*
JVM如何加载字节码文件

*
类加载器如何卸载字节码

*
IO和NIO的区别,NIO优点

*
Java线程池的实现原理,keepAliveTime等参数的作用。

*
HTTP连接池实现原理

*
数据库连接池实现原理

*
数据库的实现原理

分布式

*
什么是CAP定理

*
CAP 理论和 BASE 理论

*
CAP 理论

*
CAP 理论和最终一致性

*
最终一致性实现方式

*
CAP 理论和 BASE 理论

*
一致性 Hash

*
分布式事务,两阶段提交。

*
如何实现分布式锁

*
如何实现分布式Session

*
如何保证消息的一致性

*
负载均衡

*
正向代理(客户端代理)和反向代理(服务器端代理)

*
CDN实现原理

*
怎么提升系统的QPS和吞吐量

*
Dubbo的底层实现原理和机制

*
描述一个服务从发布到被消费的详细过程

*
分布式系统怎么做服务治理

*
接口的幂等性的概念

*
消息中间件如何解决消息丢失问题

*
Dubbo的服务请求失败怎么处理

*
重连机制会不会造成错误

*
对分布式事务的理解

*
如何实现负载均衡,有哪些算法可以实现?

*
Zookeeper的用途,选举的原理是什么?

*
数据的垂直拆分水平拆分。

*
zookeeper原理和适用场景

*
zookeeper watch机制

*
redis/zk节点宕机如何处理

*
分布式集群下如何做到唯一序列号

*
用过哪些MQ,怎么用的,和其他mq比较有什么优缺点,MQ的连接是线程安全的吗

*
MQ系统的数据如何保证不丢失

*
列举出你能想到的数据库分库分表策略;分库分表后,如何解决全表查询的问

系统架构

*
如何搭建一个高可用系统

*
哪些设计模式可以增加系统的可扩展性

*
介绍设计模式,如模板模式,命令模式,策略模式,适配器模式、桥接模式、装饰模式,观察者模式,状态模式,访问者模式。

*
抽象能力,怎么提高研发效率。

*
什么是高内聚低耦合,请举例子如何实现

*
什么情况用接口,什么情况用消息

*
如果AB两个系统互相依赖,如何解除依赖

*
如何写一篇设计文档,目录是什么

*
什么场景应该拆分系统,什么场景应该合并系统

*
系统和模块的区别,分别在什么场景下使用

*
实战能力

*
有没有处理过线上问题?出现内存泄露,CPU利用率标高,应用无响应时如何处理的。

*
开发中有没有遇到什么技术问题?如何解决的

*
如果有几十亿的白名单,每天白天需要高并发查询,晚上需要更新一次,如何设计这个功能。

*
新浪微博是如何实现把微博推给订阅者

*
Google是如何在一秒内把搜索结果返回给用户的。

*
12306网站的订票系统如何实现,如何保证不会票不被超卖。

*
如何实现一个秒杀系统,保证只有几位用户能买到某件商品。

LINUX

*
硬链接和软连接区别

*
kill用法,某个进程杀不掉的原因(进入内核态,忽略kill信号)

*
linux用过的命令

*
系统管理命令(如查看内存使用、网络情况)

*
管道的使用 |

*
grep的使用,一定要掌握,每次都会问在文件中查找

*
shell脚本

*
find命令

*
awk使用

TCP/IP

*
OSI与TCP/IP各层的结构与功能,都有哪些协议。

*
TCP与UDP的区别。

*
TCP报文结构。

*
TCP的三次握手与四次挥手过程,各个状态名称与含义,TIMEWAIT的作用。

*
TCP拥塞控制。

*
TCP滑动窗口与回退N针协议。

*
Http的报文结构。

*
Http的状态码含义。

*
Http?request的几种类型。

*
Http1.1和Http1.0的区别

*
Http怎么处理长连接。

*
Cookie与Session的作用于原理。

*
电脑上访问一个网页,整个过程是怎么样的:DNS、HTTP、TCP、OSPF、IP、ARP。

*
Ping的整个过程。ICMP报文是什么。

*
C/S模式下使用socket通信,几个关键函数。

*
IP地址分类。

*
路由器与交换机区别。

*
网络其实大体分为两块,一个TCP协议,一个HTTP协议,只要把这两块以及相关协议搞清楚,一般问题不大。

*
推荐书籍:《TCP/IP协议族》

软能力

*
如何学习一项新技术,比如如何学习Java的,重点学习什么

*
有关注哪些新的技术

*
工作任务非常多非常杂时如何处理

*
项目出现延迟如何处理

*
和同事的设计思路不一样怎么处理

*
如何保证开发质量

*
职业规划是什么?短期,长期目标是什么

*
团队的规划是什么

*
能介绍下从工作到现在自己的成长在那里

*
说说你认为的服务端开发工程师应该具备哪些能力

*
网络必备,高并发,JVM必会,各种分布式技术,看源码的能力。

*
说说你认为的架构师是什么样的,架构师主要做什么

每年的三四月份都是人才招聘的高峰期,本次小编分享几个大厂的面试题目,是希望帮助到大家,对于答案方面你可以加入我们的架构师QQ群:587372254 
私聊我发给你



同时大家应该知道六度空间理论吧,小编(我的微信:LITA941002778
)创建了很多的微信圈子,希望大家能够扩展自己的圈子,也许你的伯乐和第一桶金就在这些人里面。













人家常说:聪明人利用资源,普通人浪费资源。 我在这里等着各路大神的加入.......



友情链接
KaDraw流程图
API参考文档
OK工具箱
云服务器优惠
阿里云优惠券
腾讯云优惠券
华为云优惠券
站点信息
问题反馈
邮箱:[email protected]
QQ群:637538335
关注微信