美团面试,问的贼细~

简介: 美团校招面试涵盖网络(HTTP/TCP/UDP)、框架(Spring的IoC/AOP)、设计模式(静态代理)、编程(手写静态代理)、MySQL(事务隔离级别)、Java基础(数据类型/Integer与int的区别)、HashMap等知识点。面试从自我介绍开始,深入到技术细节,如TCP的三次握手和四次挥手,GET与POST请求的区别,以及MySQL的不可重复读示例。了解更多详情可访问[www.javacn.site](https//www.javacn.site)。

下面是美团校招的面试真题和答案解析,问的比较细,涉及到的模块有:网络、框架、设计模式(静态代理模式)、手撕代码、MySQL、Java 基础、HashMap 等知识点,接下来我们一起来看吧。
5e595e96d88d480e692a9241899e50e.jpg

1.自我介绍

自我介绍讲明白三个点:

  1. 你是谁?有几年工作经验?哪一届的学生?毕业院线?
  2. 你会啥?
  3. 你最大成就?

    2.HTTP属于传输协议的哪一层协议?

    HTTP 属于应用层,基于 TCP/IP 实现。

    3.TCP和UDP的区别?

  4. TCP 有连接;UDP 无连接。

  5. TCP 可靠;UDP 不可靠。
  6. TCP 基于数据流;UDP 基于数据报。
  7. UDP 比 TCP 更高效。
  8. TCP 发送缓冲区、接收缓冲区;UDP 只有接收缓冲区,没有发送缓冲区。

    4.TCP的可靠性传输怎么保证?

    保证可靠性的机制:

  9. 确认应答。

  10. 超时重传。
  11. 连接管理(三次握手和四次挥手)。
  12. 拥塞控制。
  13. 流量控制。

    5.如果让你设计一个协议,你怎么保证可靠性?

    可靠性主要依据:

  14. 连接管理

  15. 确认应答
  16. 超时重传

    6.TCP为什么需要三次握手?

    TCP 通讯的双方都是全双工的,所以他们彼此要证明自己和对方的发送能力和接收能力。
    TCP 如果两次握手不能证明服务器端的发送能力和客户端的接受能力 -> 两次握手。
    TCP 至少需要三次握手才能证明彼此的全双工能力。

    7.TCP为什么需要四次挥手?

    原因有两个:

  17. TCP 本身自带确认应答。

  18. TCP 有接收缓冲区的任务可能没执行完。

    8.GET和POST请求的区别?

    主要区别:

  19. 隐私性:通常情况下 POST 的隐私性高于 GET。

  20. Restful 规范:GET 用于查询;POST 用于写入操作。
  21. 传参的大小不同:GET 传参有大小限制,而 POST 没有。

    9.你刚才说GET请求传输文件大小是有限制是多少?

    不同的浏览器是不同。
    早期版本通常是 2k~4k,现在是 4K~8k。

    10.我看你博客写了很多关于Spring的东西,你可以给我说一下Spring的最重要的两大特性吗?

    Spring 核心功能:
  • IoC
  • AOP

    11.可以聊一下AOP吗?

    思路:
  1. 讲定义:AOP 面向切面编程。
  2. 讲实现
    1. 框架添加 AOP 依赖
    2. 定义切面(@Aspect)并且将它放到 IoC 容器
    3. 定义切点 -> @Pointcut 拦截规则
    4. 定义通知 -> 拦截之后的执行方法
  3. 讲原理:依靠 AOP 实现:

    1. JDK Proxy
    2. CGLib

      12.说一下静态代理的实现类图吗?

      UML 类图 -> 设计模式
      静态代理 UML 类图:
  4. 接口类

  5. 真实类(被代理的类)
  6. 代理类

    13.现在手写一个静态代理?

    14.Java基础类型有哪几个?

    Java 有以下 8 大数据类型:

  7. 整型:byte、short、int、long

  8. 浮点类型:float、double
  9. 字符类型:char
  10. 布尔类型:boolean

    15.int是几个字节?

    4个字节。

    16.int和Integer有啥区别?那你觉得哪一个用起来好,为什么?

    区别:
  • int 属于基础数据类型
  • Integer 属于对象。

使用场景:

  • int 使用场景:定义类里面的属性。
  • Integer 使用场景
    • 传参
    • 泛型
    • 对象工具方法

      17.MySQL的事务隔离级别有哪几个?

  1. 读未提交:存在脏读、不可重复读、幻读问题。
  2. 读已提交:没有脏读问题了,但是依然存在不可重复读和幻读的问题。
  3. 可重复读(默认隔离级别):没有脏读、不可重复读的问题,但依然存在幻读问题。
  4. 串行化:没有脏读、不可重复读、在幻读的问题,但效率较低。

    18.为什么读已提交有不可重复读的问题?

    读已提交会查询事务已经提交的数据,所以在两次相同的查询中,可能会读到不同的内容,这个问题就是不可重复读的问题。

    19.你可以给我模拟一下读已提交发生不可重复读的问题吗?

    begin; -- 开启事务
    select username from users where id=1; -- 张三
    -- 事务2将 users id=1 username='李四'
    -- ....
    select username from users where id=1; -- 李四
    

    20.写一个SQL语句:查询男生的数量?

    select count(*) from users where gender=1;
    

    21.根据写的SQL说一下这个里面索引是谁?生效了吗?

    考察的重点:性别是否适合做索引?

无索引,因为性别不适合做索引。

22.HashMap的底层实现原理?

HashMap 使用数组+链表/红黑树来实现的。

23.为什么HashMap要用到链表?

HashMap 会有哈希冲突,HashMap 使用的是链地址法来解决哈希冲突(实现简单、高效),所以使用链表来实现 HashMap 解决哈希冲突。

本文视频解析

飞书链接:https://r6b93q3exi.feishu.cn/docx/GBJPdy5hIoqTZNxMV8WcBDWUnHb

密码:1p6698&1

本文已收录到我的面试小站 www.javacn.site,其中包含的内容有:Redis、JVM、并发、并发、MySQL、Spring、Spring MVC、Spring Boot、Spring Cloud、MyBatis、设计模式、消息队列等模块。

相关文章
|
6天前
|
消息中间件 架构师 Java
美团面试:对比分析 RocketMQ、Kafka、RabbitMQ 三大MQ常见问题?
美团面试:对比分析 RocketMQ、Kafka、RabbitMQ 三大MQ常见问题?
美团面试:对比分析 RocketMQ、Kafka、RabbitMQ 三大MQ常见问题?
|
23天前
|
人工智能 算法 数据库
美团面试:LLM大模型存在哪些问题?RAG 优化有哪些方法?_
美团面试:LLM大模型存在哪些问题?RAG 优化有哪些方法?_
|
4月前
|
存储 关系型数据库 MySQL
美团面试:MySQL为什么 不用 Docker部署?
45岁老架构师尼恩在读者交流群中分享了关于“MySQL为什么不推荐使用Docker部署”的深入分析。通过系统化的梳理,尼恩帮助读者理解为何大型MySQL数据库通常不使用Docker部署,主要涉及性能、管理复杂度和稳定性等方面的考量。文章详细解释了有状态容器的特点、Docker的资源隔离问题以及磁盘IO性能损耗,并提供了小型MySQL使用Docker的最佳实践。此外,尼恩还介绍了Share Nothing架构的优势及其应用场景,强调了配置管理和数据持久化的挑战。最后,尼恩建议读者参考《尼恩Java面试宝典PDF》以提升技术能力,更好地应对面试中的难题。
|
3月前
|
存储 NoSQL 前端开发
美团面试:手机扫描PC二维码登录,底层原理和完整流程是什么?
45岁老架构师尼恩详细梳理了手机扫码登录的完整流程,帮助大家在面试中脱颖而出。该过程分为三个阶段:待扫描阶段、已扫描待确认阶段和已确认阶段。更多技术圣经系列PDF及详细内容,请关注【技术自由圈】获取。
|
6月前
|
SQL 缓存 关系型数据库
美团面试:Mysql 有几级缓存? 每一级缓存,具体是什么?
在40岁老架构师尼恩的读者交流群中,近期有小伙伴因未能系统梳理MySQL缓存机制而在美团面试中失利。为此,尼恩对MySQL的缓存机制进行了系统化梳理,包括一级缓存(InnoDB缓存)和二级缓存(查询缓存)。同时,他还将这些知识点整理进《尼恩Java面试宝典PDF》V175版本,帮助大家提升技术水平,顺利通过面试。更多技术资料请关注公号【技术自由圈】。
美团面试:Mysql 有几级缓存? 每一级缓存,具体是什么?
|
6月前
|
存储 安全 Java
美团面试:String 为什么 不可变 ?(90%答错了,尼恩来一个绝世答案)
45岁老架构师尼恩分享Java面试心得,涵盖String不可变性、字符串常量池、面试技巧等内容。尼恩强调,掌握深层技术原理,如String不可变性的真正原因,可在面试中脱颖而出,赢得高薪Offer。此外,尼恩还提供了大量技术资源和面试指导,帮助求职者提升技术水平,顺利通过大厂面试。
|
7月前
|
算法 Java 数据库
美团面试:百亿级分片,如何设计基因算法?
40岁老架构师尼恩分享分库分表的基因算法设计,涵盖分片键选择、水平拆分策略及基因法优化查询效率等内容,助力面试者应对大厂技术面试,提高架构设计能力。
美团面试:百亿级分片,如何设计基因算法?
|
6月前
|
SQL 关系型数据库 MySQL
美团面试:Mysql如何选择最优 执行计划,为什么?
在40岁老架构师尼恩的读者交流群中,近期有小伙伴面试美团时遇到了关于MySQL执行计划的面试题:“MySQL如何选择最优执行计划,为什么?”由于缺乏系统化的准备,小伙伴未能给出满意的答案,面试失败。为此,尼恩为大家系统化地梳理了MySQL执行计划的相关知识,帮助大家提升技术水平,展示“技术肌肉”,让面试官“爱到不能自已”。相关内容已收录进《尼恩Java面试宝典PDF》V175版本,供大家参考学习。
|
7月前
|
算法 Java 数据库
美团面试:百亿级分片,如何设计基因算法?
40岁老架构师尼恩在读者群中分享了关于分库分表的基因算法设计,旨在帮助大家应对一线互联网企业的面试题。文章详细介绍了分库分表的背景、分片键的设计目标和建议,以及基因法的具体应用和优缺点。通过系统化的梳理,帮助读者提升架构、设计和开发水平,顺利通过面试。
美团面试:百亿级分片,如何设计基因算法?
|
7月前
|
SQL 关系型数据库 MySQL
美团面试:mysql 索引失效?怎么解决? (重点知识,建议收藏,读10遍+)
本文详细解析了MySQL索引失效的多种场景及解决方法,包括破坏最左匹配原则、索引覆盖原则、前缀匹配原则、`ORDER BY`排序不当、`OR`关键字使用不当、索引列上有计算或函数、使用`NOT IN`和`NOT EXISTS`不当、列的比对等。通过实例演示和`EXPLAIN`命令分析,帮助读者深入理解索引失效的原因,并提供相应的优化建议。文章还推荐了《尼恩Java面试宝典》等资源,助力面试者提升技术水平,顺利通过面试。

热门文章

最新文章