刷了大半年Java面试题:终于拿到众多大厂offer!分享还愿

前言

今天给大家分享下我整理的Java架构面试专题及答案,其中大部分都是大企业面试常问的面试题,可以对照这查漏补缺,当然了,这里所列的肯定不可能覆盖全部方式。

很多Java开发者面试之前,可能没有较长的工作时间或者较为丰富的工作经验,所以不知道互联网公司或者一线互联网公司技术面试都会问哪些问题? 再加上可能自己准备也不充分,去面试没几个回合就被面试官几个问题打蒙了,最后以惨败收场。针对这些的读者朋友,小编整理了一些知名大厂的面经,在这分享给读者朋友们参考,让即将面试或是有想法跳槽的读者朋友们了解一下一线大厂面试时都喜欢问那些问题。

开始(部分问题没有参考答案,需要各位小伙伴下来逐一学习!)

BAT 常问的 Java基础39道常见面试题

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

2.引用数据类型

3.Switch能否用string做参数

4.equals与==的区别

5.自动装箱,常量池

6.Object有哪些公用方法

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

8.Hashcode的作用

9.HashMap的hashcode的作用

10.为什么重载hashCode方法?

11.ArrayList、LinkedList、Vector的区别

12.String、StringBuffer与StringBuilder的区别

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

14.HashMap和HashTable的区别

15.JDK7与JDK8中HashMap的实现

16.HashMap和ConcurrentHashMap的区别,HashMap的底层源码

17.ConcurrentHashMap能完全替代HashTable吗

18.为什么HashMap是线程不安全的

19.如何线程安全的使用HashMap

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

21.TreeMap、HashMap、LindedHashMap的区别

22.Collection包结构,与Collections的区别

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

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

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

26.Override和Overload的含义去区别

27.Interface与abstract类的区别

28.Static?class?与non?static?class的区别

29.foreach与正常for循环效率对比

30.Java?IO与NIO

31.java反射的作用于原理

32.泛型常用特点

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

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

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

36.JNI的使用

37.AOP是什么

38.OOP是什么

39.AOP与OOP的区别

蚂蚁金服(三面)

Zookeeper+微服务+消息中间件+高并发架构设计

一面

  1. JVM数据存储模型,新生代、年老代的构造?

  2. java GC算法,什么时候会触发minor gc,什么时候会触发full gc?

  3. GC 可达性分析中哪些算是GC ROOT?

  4. 你熟悉的JVM调优参数,使用过哪些调优工具?

  5. Java 有什么锁类型?

  6. 描述下线程池的处理流程?

  7. 类加载机制,一个类加载到虚拟机中一共有几个步骤,这些步骤的顺序哪些是固定的,哪些是不固定的,为什么不固定

  8. hashmap是线程不安全的,concurrenthashmap是线程安全的,怎么实现的线程安全?

  9. volatile关键字解决了什么问题,实现原理是什么

  10. 并发容器有哪些,并发容器和同步容器的区别

二面

  1. 在工作中,SQL语句的优化和注意的事项

  2. 哪些库或者框架用到NIO

  3. Spring 都有哪几种注入方式,什么情况下用哪种,ioc实现原理

  4. 如何定位一个慢查询,一个服务有多条SQL你怎么快速定位

  5. 聚集索引和非聚集索引知道吗?什么情况用聚集索引什么情况用非聚集索引

  6. Nosql引擎用的什么存储结构,关系型数据库和NoSQL各自的优劣点是什么,如何技术选型?

  7. 微服务架构下,如果有一个订单系统,一个库存系统,怎么保证事务?

  8. 分布式一致性协议raft,paxos 了解吗

  9. Zookeeper中的ZAB协议,选主算法

三面

  1. 自我介绍

  2. 参与的并发项目,从设计到部署,按照流程讲一遍。

  3. 项目相关你用过redis,用在什么场景,怎么使用的?

  4. mysql同步机制原理,有哪几种同步方法

  5. 数据库主从同步如何实现,事务如何实现

  6. 谈谈你对SOA和微服务的理解,以及分布式架构从应用层面涉及到的调整和挑战。

  7. 阿里系中间件metaQ及原理与现有的kafka有什么异同

  8. 在阿里有了解过什么中间件吗?实现原理?与其他开源消息队列有什么特点?

  9. 为什么选择换公司?

  10. 三年到五年的职业规划?

  11. 你有想问我的?

天猫(四面)

发压测+Mina+事务+集群+秒杀架构

一面

  1. 常见集合类的区别和适用场景

  2. 并发容器了解哪些?

  3. 如何判断链表是否有环

  4. concurrentHashMap如何实现

  5. 集群服务器 如何application 共享

  6. JAVA网络编程中:BIO、NIO、AIO的区别和联系

  7. jvm内存模型jmm 知道的全讲讲

  8. JAVA的垃圾回收,标记算法和复制算法的区别,用在什么场合?

  9. http和https的区别,http1.x和http2.0的区别,SSL和TSL之间的区别

  10. GC、G1和ZGC的区别

  11. B+树和B树的区别,和红黑树的区别

  12. 内存泄漏与内存溢出的区别

  13. session的生命周期是多久

  14. 关于Mina框架了解多少?(因为我在项目里用到了Mina,所以提到了这个部分)

二面

  1. java cas原理

  2. JAVA线程池有哪些参数,如果自己设计一个线程池要考虑哪些问题?

  3. Java的lock的底层实现?

  4. mysql数据库默认存储引擎,有什么优点

  5. MySQL的事务隔离级别,分别解决什么问题。

  6. 四个表 记录成绩,每个大约十万条记录,如何找到成绩最好的同学

  7. 常见的负载均衡算法有哪些

  8. 如果Redis有1亿个key,使用keys命令是否会影响线上服务

  9. Redis的持久化方式,aod和rdb,具体怎么实现,追加日志和备份文件,底层实现原理的话知道么

三面

  1. 请画一个完整大型网站的分布式服务器集群部署图

  2. 多个RPC请求进来,服务器怎么处理并发呢

  3. 讲一下Redis的哨兵机制

  4. 数据库分库分表一般数据量多大才需要?

  5. 如何保证数据库与redis缓存一致的

  6. 项目中消息队列怎么用的?使用哪些具体业务场景?

  7. JVM相关的分析工具有使用过哪些?具体的性能调优步骤吗?

  8. MySQL的慢sql优化一般如何来做?除此外还有什么方法优化?

  9. 线上的服务器监控指标,你认为哪些指标是最需要关注的?为什么?

  10. 如何做压测,抗压手段

  11. 秒杀模块怎么设计的

HR面

  1. 自我介绍

  2. 你怎么评价你之前的3轮面试

  3. 你怎么看待你自己,你最大的核心竞争力是什么

  4. 未来自己的职业规划

  5. 对阿里技术氛围有什么样的理解,用过哪些阿里的开源库

  6. 期望的薪资是多少

  7. 最后,你有什么想了解的

文末评论“面试”:添加助理VX:MXW5308 即可免费获取

阿里高级java面试题和答案

一面面试题目:

1、你比较了解的机器学习的算法有哪些,说一下这些算法的过程和区别

2、网络的体系结构分为哪五层,每层分别有哪些协议

3、TCP和UDP的区别是什么,如果想发送即时消息应该用哪种协议

4、TCP的连接建立和断开的过程(三次握手和四次挥手),如何保证TCP发送的信息是正确的,且保证其先后顺序不被篡改

5、对HTTP协议了解多少,HTTP和HTTPS有什么区别,HTTPS的安全性是怎么实现的

6、平时用mysql用什么引擎

7、数据库事务的特性有哪些

8、事务并发可能会导致哪些问题,数据库的隔离级别有哪些,mysql默认的是哪种级别,这种默认的隔离级别能够避免哪些问题(复习的太久了,有一些忘记了,这个问题居然答得不全)

9、如何判断SQL查询操作是不是慢sql,如何优化

10、进程和线程的区别,进程之间的通信方法

11、死锁是什么,处理死锁的方法有哪些

12、进程同步中的临界区有什么处理方法

13、spring MVC,spring AOP源码

14、spring循环引用

15、spring事务传播机制

16、java nio,bio,aio,操作系统底层nio实现原理

17、java线程编程了解吗?

18、hashmap的数据结构是什么,具体是怎么实现的,是不是线程安全的(不是),那么它的线程安全的替代有哪些?

二面面试题目和参考答案:

你在项目中遇到哪些有挑战性的点?

参考:参与了秒杀的高并发项目。

1.流量在某一时刻暴涨,然后又猛跌如何应对?

参考答案:

  • 流量削峰填谷

  • 在客户端与服务器加入消息队列作为缓存机制

  • 接入层与各模块都采用cache增加QPS

2.redis 消息队列如何对过期信息/无效信息进行删除

参考答案:

  • 添加过期时间上限

  • 不同组团信息采用不同队列,当该组团满额之后删除队列

3.redis 的持久化机制?

  • 参考答案:RDB和AOF

4. 为什么JAVA类加载要用双亲委派

  • 实例:Object类唯一

5.怎么实现同步

  • Synchronized关键字

  • Volatile变量

  • Lock对象

6. JAVA锁有哪几种

  • Sychronized

  • ReentrantLock

7. 两种锁的区别

  • Synchronized 由JVM实现

  • ReentrantLock 由JDK实现

6. 了解过AQS吗?

  • AQS(Abstract Queue Synchronizer)队列同步器

  • 由一个Valotaile变量标记状态State,以及一个CLH(同步、FIFO)队列构成

具体实现类:

  • CountdownLatch: 等待多个线程完成;

  • CyclicBarrier:同步屏障;

  • Semaphore:控制并发线程数。

7. 场景题:给一个方法加上超时异常

  • 使用AspectJ进行AOP开发

  • 将方法调用进行Around切入

  • 采用Future对象创建一个线程,在调用方法同时进行计时

  • 若Future率先返回值则抛出超时异常

  • 否则则正常调用

文末评论“面试”:添加助理VX:MXW5308 即可免费获取

Java开发岗位面试题归类汇总(文末有相关面试答案)

一、Java基础

1. String类为什么是final的

2. HashMap的源码,实现原理,底层结构。

3. 说说你知道的几个Java集合类:list、set、queue、map实现类。

4. 描述一下ArrayList和LinkedList各自实现和区别

5. Java中的队列都有哪些,有什么区别。

6. 反射中,Class.forName和classloader的区别。

7. Java7、Java8的新特性

8. Java数组和链表两种结构的操作效率,在哪些情况下(从开头开始,从结尾开始,从中间开始),哪些操作(插入,查找,删除)的效率高。

9. Java内存泄露的问题调查定位:jmap,jstack的使用等等。

10. string、stringbuilder、stringbuffer区别

11. hashtable和hashmap的区别

13 .异常的结构,运行时异常和非运行时异常,各举个例子。

14. String 类的常用方法

16. Java 的引用类型有哪几种

17. 抽象类和接口的区别

18. java的基础类型和字节大小

19. Hashtable,HashMap,ConcurrentHashMap底层实现原理与线程安全问题。

20. 如果不让你用Java Jdk提供的工具,你自己实现一个Map,你怎么做。说了好久,说了HashMap源代码,如果我做,就会借鉴HashMap的原理,说了一通HashMap实现。

21. Hash冲突怎么办?哪些解决散列冲突的方法?

22. HashMap冲突很厉害,最差性能,你会怎么解决?从O(n)提升到log(n)。

23. rehash

24. hashCode() 与 equals() 生成算法、方法怎么重写。

二、Java IO

1. 讲讲IO里面的常见类,字节流、字符流、接口、实现类、方法阻塞。

2. 讲讲NIO

3. String 编码UTF-8 和GBK的区别?

4. 什么时候使用字节流、什么时候使用字符流?

5. 递归读取文件夹下的文件,代码怎么实现?

三、Java Web

1. session和cookie的区别和联系,session的生命周期,多个服务部署时session管理。

2. servlet的一些相关问题

3. webservice相关问题

4. jdbc连接,forname方式的步骤,怎么声明使用一个事务。

5. 无框架下配置web.xml的主要配置内容

6. jsp和servlet的区别

四、JVM

1. Java的内存模型以及GC算法

2. jvm性能调优都做了什么

3. 介绍JVM中7个区域,然后把每个区域可能造成内存的溢出的情况说明。

4. 介绍GC 和GC Root不正常引用

5. 自己从classload 加载方式,加载机制说开去,从程序运行时数据区,讲到内存分配,讲到String常量池,讲到JVM垃圾回收机制,算法,hotspot。

6. jvm 如何分配直接内存, new 对象如何不分配在堆而是栈上,常量池解析。

7. 数组多大放在JVM老年代

8. 老年代中数组的访问方式

9. GC 算法,永久代对象如何 GC , GC 有环怎么处理。

10. 谁会被 GC ,什么时候 GC。

11. 如果想不被 GC 怎么办

12. 如果想在 GC 中生存 1 次怎么办

五、开源框架

1. hibernate和ibatis的区别

2. 讲讲mybatis的连接池

3. spring框架中需要引用哪些jar包,以及这些jar包的用途

4. springMVC的原理

5. springMVC注解的意思

6. spring中beanFactory和ApplicationContext的联系和区别

7. spring注入的几种方式

8. spring如何实现事物管理的

9. springIOC

10. spring AOP的原理

11. hibernate中的1级和2级缓存的使用方式以及区别原理(Lazy-Load的理解)

12. Hibernate的原理体系架构,五大核心接口,Hibernate对象的三种状态转换,事务管理。

六、多线程

1. Java创建线程之后,直接调用start()方法和run()的区别

2. 常用的线程池模式以及不同线程池的使用场景

3. newFixedThreadPool此种线程池如果线程数达到最大值后会怎么办,底层原理。

4. 多线程之间通信的同步问题,synchronized锁的是对象,衍伸出和synchronized相关很多的具体问题,例如同一个类不同方法都有synchronized锁,一个对象是否可以同时访问。或者一个类的static构造方法加上synchronized之后的锁的影响。

5. 了解可重入锁的含义,以及ReentrantLock 和synchronized的区别

6. 同步的数据结构,例如concurrentHashMap的源码理解以及内部实现原理,为什么他是同步的且效率高。

7. atomicinteger和Volatile等线程安全操作的关键字的理解和使用

8. 线程间通信,wait和notify

9. 定时线程的使用

10. 场景:在一个主线程中,要求有大量(很多很多)子线程执行完之后,主线程才执行完成。多种方式,考虑效率。

11. 进程和线程的区别

12. 什么叫线程安全?

13. 线程的几种状态

14. 并发、同步的接口或方法

15. HashMap 是否线程安全,为何不安全。ConcurrentHashMap,线程安全,为何安全。底层实现是怎么样的。

16. J.U.C下的常见类的使用。ThreadPool的深入考察;BlockingQueue的使用。(take,poll的区别,put,offer的区别);原子类的实现。

17. 简单介绍下多线程的情况,从建立一个线程开始。然后怎么控制同步过程,多线程常用的方法和结构

18. volatile的理解

19. 实现多线程有几种方式,多线程同步怎么做,说说几个线程里常用的方法。

七、网络通信

1. http是无状态通信,http的请求方式有哪些,可以自己定义新的请求方式么。

2. socket通信,以及长连接,分包,连接异常断开的处理。

3. socket通信模型的使用,AIO和NIO。

4. socket框架netty的使用,以及NIO的实现原理,为什么是异步非阻塞。

5. 同步和异步,阻塞和非阻塞。

6. OSI七层模型,包括TCP,IP的一些基本知识

7. http中,get post的区别

8. 说说http,tcp,udp之间关系和区别。

9. 说说浏览器访问http://www.taobao.com,经历了怎样的过程。

10. HTTP协议、 HTTPS协议,SSL协议及完整交互过程;

11. tcp的拥塞,快回传,ip的报文丢弃

12. https处理的一个过程,对称加密和非对称加密

13. head各个特点和区别

14. 说说浏览器访问http://www.taobao.com,经历了怎样的过程。

八、数据库MySql

1. MySql的存储引擎的不同

2. 单个索引、联合索引、主键索引

3. Mysql怎么分表,以及分表后如果想按条件分页查询怎么办

4. 分表之后想让一个id多个表是自增的,效率实现

5. MySql的主从实时备份同步的配置,以及原理(从库读主库的binlog),读写分离。

6. 写SQL语句和SQL优化

7. 索引的数据结构,B+树

8. 事务的四个特性,以及各自的特点(原子、隔离)等等,项目怎么解决这些问题。

9. 数据库的锁:行锁,表锁;乐观锁,悲观锁

10. 数据库事务的几种粒度

11. 关系型和非关系型数据库区别

九、设计模式

1. 单例模式:饱汉、饿汉。以及饿汉中的延迟加载,双重检查。

2. 工厂模式、装饰者模式、观察者模式。

3. 工厂方法模式的优点(低耦合、高内聚,开放封闭原则)

十、算法

1. 使用随机算法产生一个数,要求把1-1000W之间这些数全部生成。

2. 两个有序数组的合并排序

3. 一个数组的倒序

4. 计算一个正整数的正平方根

5. 说白了就是常见的那些查找、排序算法以及各自的时间复杂度。

6. 二叉树的遍历算法

7. DFS,BFS算法

9. 比较重要的数据结构,如链表,队列,栈的基本理解及大致实现。

10. 排序算法与时空复杂度(快排为什么不稳定,为什么你的项目还在用)

11. 逆波兰计算器

12. Hoffman 编码

13. 查找树与红黑树

十一、并发与性能调优

1. 有个每秒钟5k个请求,查询手机号所属地的笔试题,如何设计算法?请求再多,比如5w,如何设计整个系统?

2. 高并发情况下,我们系统是如何支撑大量的请求的

3. 集群如何同步会话状态

4. 负载均衡的原理

5 .如果有一个特别大的访问量,到数据库上,怎么做优化(DB设计,DBIO,SQL优化,Java优化)

6. 如果出现大面积并发,在不增加服务器的基础上,如何解决服务器响应不及时问题“。

7. 假如你的项目出现性能瓶颈了,你觉得可能会是哪些方面,怎么解决问题。

8. 如何查找 造成 性能瓶颈出现的位置,是哪个位置照成性能瓶颈。

9. 你的项目中使用过缓存机制吗?有没用用户非本地缓存

十二、其他

以上就是一些知名大厂的面试经过以及面试高频考点,小编在这分享总结的Java面试的高频面试题(包括了Java集合,JVM,并发与多线程,Spring,MyBaits,微服务,Dubbo,Kakfa,中间件,Redis,数据库,设计模式、Zookeeper、分布式等),进行了整理,免费分享给大家。

Java大厂高频面试题答案获取方式:关注小编,文末评论“面试”:添加助理VX:MXW5308 即可免费获取。

Java大厂高频面试题答案获取方式:关注小编,文末评论“面试”:添加助理VX:MXW5308 即可免费获取。