2020年终总结:美团+滴滴+网易+拼多多Java后端面经总结,最终上岸网易!

目录

前言

一、美团五面

一面

二面

三面

四面

HR

二、滴滴一面凉经​

12.21晚上7点电话面试,45分钟~

三、网易面经汇总

Java基础

数据结构和算法

JVM

多线程

数据库相关

计算机网络

设计模式

分布式相关

缓存相关

框架相关

一些较新的东西

四、拼多多三面

一面

二面

三面

总结


前言

今年秋招较以往是要难了一些,但也不是那种遥不可及的地步。对于准备充分的人来说总是offer不断。我接触Java也不到1年,但是只要好好的准备,两个月完全够应付大部分的公司了。希望看到这篇文章的同学能稳住心态,踏实刷题。坚持几个月定能收获自己满意的offer。

2020年终总结:美团+滴滴+网易+拼多多Java后端面经总结,最终上岸网易!_第1张图片

一、美团五面

2020年终总结:美团+滴滴+网易+拼多多Java后端面经总结,最终上岸网易!_第2张图片

一面

  1. 介绍自己
  2. 项目
    1. 介绍项目(我写的一个辣鸡的秒模块,泪了)
    2. 怎么保证Redis与Mysql的数据一致性(秒杀预热数据的一致性,就解释了不需要一致性,只保证Mysql库存正确即可之类的)
    3. 见你写了个加随机数预防缓存雪崩,解释一下
    4. 未改进和改进后的Jmter测试性能对比
  3. Redis
    1. 为什么选择Redis作为缓存?
    2. 为什么Redis的性能十分的高?
    3. 说一下单进程、单线程的Redis和你平时写的多线程程序的对比
    4. 如何保证Redis的高可用(哨兵、持久化策略RDB、AOF)
    5. 解释一下哨兵、RDB、AOF
    6. 主从一致性
      1. 大概答了在哨兵中RDB和AOF是怎么配合使用来保证主从一致
      2. 几个方面
        1. 从刚启动
        2. 主从同步
        3. 主掉线切换
    7. Redis数据淘汰策略
    8. 说一下分布式事务吗?
      1. 不太了解,所以大概答了思路:通过事务实现Mysql和Redis的同步修改,异常回滚啥的
    9. setnx是事务吗?
      1. 答了不是(不知道对不对),然后又说了一下Redis本身自带的事务(部分事务,非原子性)
  4. Mysql
    1. 解释一下事务
    2. 事务隔离级别
      1. 答了并发问题及其对应解决
      2. 答了RC和RR级别事务的实现:一致性视图、MVCC
    3. 为什么使用B+树作为索引(答了二叉树、B树、B+树的对比及其应用的优缺点)
    4. 聚簇索引和非聚簇索引的区别
      1. 答了聚簇索引:结构、建立(主键上建立、无主键则选择第一个唯一索引,若都没有主键和唯一索引则隐藏有一个字段实现聚簇索引)
      2. 非聚簇结构、回表问题
    5. 什么是最左匹配原则(答了:建立多列索引、多列索引顺序性和索引下推)
  5. Java
    1. Java是如何保证其安全性的
      1. 答了封装字段访问权限
      2. 答了C语言手动内存管理和JVM GC保证一定程度上的内存安全、内存不泄露
    2. 刚见你说了Java 内存泄漏问题,解释一下什么情况下会出现
      1. 答了强引用
      2. 答了线程池里的线程使用ThreadLocal 自己忘记回收、需要线程回收了才会回收占用的内存造成内存泄漏,如果***存很大会造成频繁的GC极大拖慢进程的速度
    3. 说一下BIO、NIO、AIO
      1. 答了区别、优点缺点、实现机制
  6. 手撕算法
    1. 一个数组找出出现次数最多的一个数,如果多个数出现的次数相同则输出第一个
    2. 生产者消费者(一对一)
  7. 平时怎么学习的
  8. 有什么需要问的吗?

面试官很nice,大概面了一个小时

挖槽。。。这也太快了,给我过了,明天下午4点二面

二面

面试官想到啥就问啥,不会的问题会去有引导你,面试的体验很不错,希望有三面。。。

  1. 手撕
    1. 10个多线程保证 i从0加到10 (差点翻车,主线程忙等另外10个线程完结
    2. 反转链表
    3. 上台阶(n=80)
  2. 操作系统
    1. 常用的linux命令说一下
    2. 操作系统中的信号 和 信号量有什么关系
    3. epoll 和 Selector 有什么区别?
  3. 计算机网络
    1. 说一下拥塞控制
  4. 数据结构
    1. 说一下红黑树,你平时用的技术哪里用到了它
    2. 哈希表怎么处理冲突
  5. 项目
    1. 你把项目放到服务器上运行的时候有没有遇到什么问题?查看项目运行的状态怎么做?
    2. spring 和 springboot的关系你是怎么理解的
    3. Spring IOC和AOP说一下你的理解
    4. 为什么用消息队列
    5. 对于消息的重复消费你有什么设计方案吗?
  6. 最近有在学什么?平时是怎么学习的?

下面是小编整理的MySQL思维导图,需要了解的朋友可以点击看看

三面

233之前HR说是技术面试,怎么好像变成了HR面了...

  1. 介绍自己
  2. 说一下四种IO模型
  3. 平时怎么去学习的?
  4. 为什么你说学习了要去实践?
  5. 说一下的最大的优点和缺点
  6. 举一下你缺点的例子
  7. 相像一下几十年后是怎样的生活
  8. 你觉得最痛苦的一段时间
  9. 对你影响最大的一件事情
  10. 在安排活动的过程中有没有发生什么冲突?
  11. 你有什么崇拜的人吗?
  12. 你有什么想问的?

四面

应该是主管吧...

  1. 介绍学习过程和感悟
  2. 看你用过vue,介绍一下
  3. webpack打包工具介绍一下
  4. csrf攻击说一下
  5. 见你写了,了解python说一下
  6. 说一下python的yield的用法(不会=。=)
  7. 看你说对机器学习有了解,说一下学习经历(介绍了学习经历、还有机器学习、深度学习的相关知识:常机器学习常用算法、神经网络反向传播啥的、还有训练、网络优化损失函数啥的)
  8. 浮点数的立方(凉)(说了转成字符串然后模拟乘法计算)
  9. 某个数的开方(凉)(说了逼近,,,实际可以除2或者牛顿法...)
  10. 有什么想问的吗?比如业务、技术栈什么的?(问了业务和技术栈,面试官介绍了挺久的)

555菜哭了,希望有HR面.................

HR

HR正常问题:学校经历、性格、优点缺点、学习方法、与人相处、他人评价

二、滴滴一面凉经
2020年终总结:美团+滴滴+网易+拼多多Java后端面经总结,最终上岸网易!_第3张图片

12.21晚上7点电话面试,45分钟~

  1. 问项目
  2. synchronized底层实现,与lock的区别
  3. 代码如下:

    1

    2

    3

    4

    HashMapmap;

    class Student{

        String name;

    }

    问:往map里插入一个student,修改这个student的name属性,是否还能get到
  4. String a = "1";
    int b = 1;
    问:a.equals(b)?,为什么
  5. 如何缓解哈希碰撞
  6. TCP、HTTP协议
  7. spring MVC如何处理前端发送来的请求
  8. 说说5个你用过的注解
  9. spring是怎么解析json的,说说你用过的json解析器
  10. 手撕SQL:1.连接 2.group by算各个班平均年龄
  11. SQL的分表操作
  12. 如何做权限管理
  13. 接下来是一道开放问题:线上服务器的一个日志重复出现了两次,如何排查问题
  14. 如何看线程的运行情况
  15. 最近在学啥
  16. 反问

一面之后没收到过消息了,应该凉凉,不过面试体验很不错~

三、网易面经汇总

2020年终总结:美团+滴滴+网易+拼多多Java后端面经总结,最终上岸网易!_第4张图片

Java基础

1.HashMap的源码,实现原理,JDK8中对HashMap做了怎样的优化。

2.HaspMap扩容是怎样扩容的,为什么都是2的N次幂的大小。

3.HashMap,HashTable,ConcurrentHashMap的区别。

4.极高并发下HashTable和ConcurrentHashMap哪个性能更好,为什么,如何实现的。

5.HashMap在高并发下如果没有处理线程安全会有怎样的安全隐患,具体表现是什么。

6.java中四种修饰符的限制范围。

7.Object类中的方法。

8.接口和抽象类的区别,注意JDK8的接口可以有实现。

9.动态代理的两种方式,以及区别。

10.Java序列化的方式。

11.传值和传引用的区别,Java是怎么样的,有没有传值引用。

12.一个ArrayList在循环过程中删除,会不会出问题,为什么。

13.@transactional注解在什么情况下会失效,为什么。

数据结构和算法

1.B+树

2.快速排序,堆排序,插入排序(其实八大排序算法都应该了解

3.一致性Hash算法,一致性Hash算法的应用

JVM

1.JVM的内存结构。

2.JVM方法栈的工作过程,方法栈和本地方法栈有什么区别。

  • 蚂蚁金服内部解密的JVM调优笔记和案例分享实战

3.JVM的栈中引用如何和堆中的对象产生关联。

4.可以了解一下逃逸分析技术。

5.GC的常见算法,CMS以及G1的垃圾回收过程,CMS的各个阶段哪两个是Stop the world的,CMS会不会产生碎片,G1的优势。

6.标记清除和标记整理算法的理解以及优缺点。

7.eden survivor区的比例,为什么是这个比例,eden survivor的工作过程。

8.JVM如何判断一个对象是否该被GC,可以视为root的都有哪几种类型。

9.强软弱虚引用的区别以及GC对他们执行怎样的操作。

10.Java是否可以GC直接内存。

11.Java类加载的过程。

12.双亲委派模型的过程以及优势。

13.常用的JVM调优参数。

14.dump文件的分析。

15.Java有没有主动触发GC的方式(没有)。

多线程

1.Java实现多线程有哪几种方式。

2.Callable和Future的了解。

3.线程池的参数有哪些,在线程池创建一个线程的过程。

4.volitile关键字的作用,原理。

5.synchronized关键字的用法,优缺点。

6.Lock接口有哪些实现类,使用场景是什么。

7.可重入锁的用处及实现原理,写时复制的过程,读写锁,分段锁(ConcurrentHashMap中的segment)

8.悲观锁,乐观锁,优缺点,CAS有什么缺陷,该如何解决。

9.ABC三个线程如何保证顺序执行。

10.线程的状态都有哪些。

11.sleep和wait的区别。

12.notify和notifyall的区别。

13.ThreadLocal的了解,实现原理。

数据库相关

1.常见的数据库优化手段

2.索引的优缺点,什么字段上建立索引

3.数据库连接池。

4.durid的常用配置。

计算机网络

1.TCP,UDP区别。

2.三次握手,四次挥手,为什么要四次挥手。

3.长连接和短连接。

4.连接池适合长连接还是短连接。

设计模式

1.观察者模式

2.代理模式

3.单例模式,有五种写法,可以参考文章单例模式的五种实现方式

4.可以考Spring中使用了哪些设计模式

分布式相关

1.分布式事务的控制。

2.分布式锁如何设计。

3.分布式session如何设计。

4.dubbo的组件有哪些,各有什么作用。

5.zookeeper的负载均衡算法有哪些。

6.dubbo是如何利用接口就可以通信的。

缓存相关

1.redis和memcached的区别。

2.redis支持哪些数据结构。

3.redis是单线程的么,所有的工作都是单线程么。

4.redis如何存储一个String的。

5.redis的部署方式,主从,集群。

6.redis的哨兵模式,一个key值如何在redis集群中找到存储在哪里。

7.redis持久化策略。

框架相关

1.SpringMVC的Controller是如何将参数和前端传来的数据一一对应的。

2.Mybatis如何找到指定的Mapper的,如何完成查询的。

3.Quartz是如何完成定时任务的。

4.自定义注解的实现。

5.Spring使用了哪些设计模式。

6.Spring的IOC有什么优势。

7.Spring如何维护它拥有的bean。

一些较新的东西

1.JDK8的新特性,流的概念及优势,为什么有这种优势。

2区块链了解

3.如何设计双11交易总额面板,要做到高并发高可用。

四、拼多多三面

2020年终总结:美团+滴滴+网易+拼多多Java后端面经总结,最终上岸网易!_第5张图片

一面

1、询问工作经历,在项目中如何做性能优化的?

2、有用过状态管理吗?说说redux 的理念;

3、flex: 0 1 auto; 是什么意思?

4、less 的 & 代表什么?

5、react 16 生命周期有什么改变?

6、详细的介绍一下 getDerivedStateFromProps

7、interface 和 type 的区别

(1)type可以声明 基本类型,联合类型,元组 的别名,interface不行

(2)type 语句中可以使用 typeof 获取类型实例

(3)type 支持类型映射,interface不支持

(4)interface能够声明合并,type不能

8、有用过ssr 吗?

9、node 熟悉吗?

10、算法题:

求最大公共前缀

相关知识点: 字符串

相关知识点: 字符串

二面

1、webpack 如何实现动态加载

2、react 里有动态加载的 api 吗?

3、React.lazy 的原理是什么?

4、webpack 能动态加载 require 引入的模块吗?

5、require 引入的模块 webpack 能做 Tree Shaking 吗?

6、设计一个input 组件需要哪些属性?

7、value 的类型是什么?

8、有一个a标签,如何动态的决定他的样式。

9、import 和 require 导入的区别

(1)require 是 AMD规范引入方式;import是es6的一个语法标准,如果要兼容浏览器的话必须转化成es5的语法

(2)require是运行时调用,所以require理论上可以运用在代码的任何地方;import是编译时调用,所以必须放在文件开头

(3)本质上,require是赋值过程,其实require的结果就是对象、数字、字符串、函数等,再把require的结果赋值给某个变量;而import是解构过程,但是目前所有的引擎都还没有实现import,我们在node中使用babel支持ES6,也仅仅是将ES6转码为ES5再执行,import语***被转码为require;

10、require 有什么性能问题

11、class 组件与函数式组件的区别

12、css 优先级

答:important > 内联 > ID选择器 > 类选择器 > 标签选择器

13、避免 css 全局污染。

14、css modules 的原理

15、组件库如何做按需加载

16、onChange 怎么规定 value 的类型

17、interface 和 type 的区别

18、写一个 promise 重试函数,可以设置时间间隔和次数。

三面

1、组件平台有哪些功能?然后详细的跟我讨论组件平台的设计。

2、实现一个 redux。实现 createStore 的功能,关键点发布订阅的功能,以及取消订阅的功能。

3、用 ts 实现一个 redux;

总结

上面的面试题小编已经整理成文档(附答案)小编这边还整理了一些Spring Cloud与Docker微服务架构实战270多页的资料集锦,Spring Boot 学习笔记100多页,以及Spring全家桶(1187页PDF),1000道互联网大厂Java工程师面试题,关注公众号:麒麟改bug。

你可能感兴趣的:(JAVA核心技术,大厂必备Java面试题,java,网易,编程语言,redis,面试)