滴滴26届实习后端面经➕复盘➕内推

🔥作者背景:985本硕,Java技术栈,有分布式系统项目经验,一段中厂实习经历,LeetCode刷题100+。
🚀就在4月15日滴滴的26届实习岗位终于开了,为了让学弟学妹快速投递成功,我总结了一下去年滴滴后端的面经。
✨(最后附加内推码,有需要的可以自取!)闲话少说!直接开盘!!

一面(60分钟)
项目深挖
详细介绍简历中物流信息共享平台项目,重点说明SSM框架整合、Vue前端数据绑定问题、服务器部署和域名解析过程。
✨追问:
Git版本控制冲突如何解决?是否用过rebase/cherry-pick?(引用项目中使用GitHub协作经验)
JVM内存调优经验?答未关注,但提到用Linux命令监控CPU和内存,面试官表示认可。
基础知识
✨Java:
JVM内存结构(堆、栈、方法区区别)
 equals 与 == 区别,String类重写机制。
✨数据库:
MySQL索引失效场景,联合索引最左匹配原则。
✨操作系统:
进程与线程区别,协程的应用场景(结合Golang项目提问)。

算法题
题目:LC438 找出字符串中所有字母异位词(滑动窗口解法)。
复盘:面试官要求分析暴力解与滑动窗口的时间复杂度差异,并手写代码。

二面(80分钟)
系统设计
设计一个高并发订单系统:
分库分表策略(用户ID哈希 vs 时间范围)。
缓存穿透解决方案(布隆过滤器+缓存空值)。
底层原理
Kafka:
消息持久化机制、ISR副本同步原理。
Redis:
集群模式(Codis vs Redis Cluster),分布式锁实现(RedLock算法缺陷)。
场景题
服务端与客户端TCP连接中途断网,如何检测并恢复?(答心跳机制+重连策略,面试官补充Keepalive参数配置)。
代码题
括号匹配(栈的应用),要求处理嵌套和非法字符。

三面(40分钟)
职业规划
为什么选择滴滴?对出行行业技术挑战的理解(提及实时调度算法、大数据风控)。
团队适配
能否接受出差/轮岗?举例说明抗压能力(用实习期通宵上线经历回答)。
反问环节
团队技术栈:Go为主,Java/Python辅助,自研中间件较多。

✨内推链接:https://app.mokahr.com/m/campus_apply/didiglobal/96064?recommendCode=DSW46Dg7&hash=%23%2Fjobs#/jobs
【内推码】DSW46Dg7

内推简历优先筛选,避免卡在池子里。HR面后可通过内推人查询排序状态,避免焦虑等待。

秋招Tips:滴滴面试官对项目细节抠得细,建议提前画好技术架构图,并准备1-2个“踩坑-解决-复盘”的完整故事,通过率提升50%!
#实习# #校招# #应届# #滴滴秋储# #2026届实习生# #秋招提前批# #滴滴# #滴滴出行# #后端面经#
全部评论

相关推荐

字节跳动前端二面失败面经:复盘与反思一、面试整体感受本次字节跳动前端二面的考核强度明显提升,面试官从计算机基础、CSS 知识,到 JavaScript 核心概念与实践应用层层深入,虽然最终遗憾未通过,但这次经历让我清晰认识到自身知识体系的薄弱环节。二、面试问题回顾与解析1. CS 基础与 CSS 考察• 实现父容器一半大小的正方形:我第一反应是使用 vw 单位,将子容器的 width 和 height 都设置为 50vw。但面试官的意图更倾向于基于父容器尺寸的相对计算,正确思路应该是通过百分比结合 padding-bottom 实现等比例正方形(如 width: 50%; padding-bottom: 50%;),并利用 position 或 flex 布局定位到父容器内。• CSS 盒模型:我准确回答了 标准盒模型(content-box) 和 怪异盒模型(border-box) 的区别,重点说明了 box-sizing 属性对尺寸计算的影响。2. JavaScript 核心概念与 BOM 考察• BOM(浏览器对象模型):当被问到 BOM 相关知识时,我对 window 对象的属性(如 location、history)和方法(setTimeout、addEventListener 等)掌握不够熟练,回答较为模糊,暴露出日常学习中对浏览器环境底层知识的忽视。• 事件委托:面试官询问事件委托原理时,我错误地将其等同于事件冒泡。实际上,事件委托是利用事件冒泡机制,将子元素的事件处理委托给父元素,从而减少内存占用和提高性能。例如,在列表项点击事件中,可将点击事件绑定在列表容器上,通过判断事件源 event.target 处理具体逻辑。3. 代码实战环节• 实现 JavaScript 链式调用并支持 bind 功能:题目要求实现类似 i.initial(5).add(5).minus(3).plus(5).result 的链式调用,并能使用 bind 修改内部状态。我顺利完成了基础的链式调用逻辑,通过返回 this 实现连续调用,并维护一个内部变量记录计算结果:function Chain() {  this.value = 0;  this.initial = function (num) {    this.value = num;    return this;  };  this.add = function (num) {    this.value += num;    return this;  };  this.minus = function (num) {    this.value -= num;    return this;  };  this.plus = function (num) {    this.value += num;    return this;  };  this.result = function () {    return this.value;  };}但在实现 bind 功能时,由于对 bind 改变函数 this 指向的原理理解不足,未能完成。正确思路是通过 Function.prototype.bind 方法创建一个新函数,在新函数中调用原始方法,并传入绑定的参数和 this 值。• 封装安全的 React Hook:需求是处理可能失败的异步请求,并确保数据安全。我通过 useState 和 useEffect 实现了一个简单的 fetch 请求钩子,在 catch 块中处理错误,并添加了加载状态和错误信息的状态管理:import { useState, useEffect } from'react';const useSafeFetch = (url) => {  const [data, setData] = useState(null);  const [loading, setLoading] = useState(true);  const [error, setError] = useState(null);  useEffect(() => {    const fetchData = async () => {      try {        const response = await fetch(url);        const result = await response.json();        setData(result);      } catch (err) {        setError(err);      } finally {        setLoading(false);      }    };    fetchData();  }, [url]);  return { data, loading, error };};• 手写 JSONP 函数:要求传入 URL、成功回调、失败回调和超时时间。由于对 window 对象动态创建 script 标签、onerror 和 onload 事件,以及 clearTimeout 等原生方法不够熟悉,最终未能完整实现。正确实现思路如下:function jsonp(url, successCallback, errorCallback, timeout) {  const script = document.createElement('script');  const callbackName = `jsonp_callback_${Date.now()}`;  window[callbackName] = (data) => {    clearTimeout(timer);    document.body.removeChild(script);    successCallback(data);  };  script.src = `${url}&callback=${callbackName}`;  script.onerror = () => {    clearTimeout(timer);    delete window[callbackName];    errorCallback(new Error('JSONP request failed'));  };  document.body.appendChild(script);  const timer = setTimeout(() => {    document.body.removeChild(script);    delete window[callbackName];    errorCallback(new Error('JSONP request timed out'));  }, timeout);}三、总结与反思此次面试失败暴露出我在 BOM 细节、事件机制、函数绑定原理 等基础知识上的不足,以及 复杂场景下代码实现能力 的欠缺。未来准备面试时,需更深入理解 JavaScript 原型链、作用域、this 机制等核心概念,同时加强手写代码的练习,尤其是对原生 API 的熟练运用。希望我的经历能为大家提供参考,避免踩坑!
字节跳动二面503人在聊 查看7道真题和解析
点赞 评论 收藏
分享
评论
3
9
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务