2025/2/25,字节跳动后端开发一面面经
一、双方简单自我介绍
面试官先自我介绍,之后属于面试官看简历过程,基本不听。
二、实习中遇到最难的事情,怎么解决的
主要问的还是实习中做过的项目,项目难点在哪里(自己参与的地方),面对困难是怎么思考,怎么实际操作解决的。
三、项目实现细节
掌握自己项目的实现细节,否则容易让面试官怀疑项目的真实性。
四、八股
1、浏览器从输入网址到呈现整个流程
键盘输入
输入键盘字符后键盘就会产生扫描数据,并将其缓冲存在寄存器中,然后键盘通过总线给 CPU 发送中断请求。CPU 收到中断请求后,操作系统会保存被中断进程的 CPU 上下文,然后调用键盘的中断处理程序。键盘中断处理函数从键盘的寄存器的缓冲区读取扫描码,再根据扫描码找到用户在键盘输入的字符的ASCII 码。然后把 ASCII 码放到读缓冲区队列,显示器会定时从读缓冲区队列读取数据放到写缓冲区队列,最后把写缓冲区队列的数据一个一个写入到显示器的寄存器中的数据缓冲区,最后将这些数据显示在屏幕里。
URL解析
浏览器会首先从缓存中找是否存在域名,如果存在就直接取出对应的ip地址,如果浏览器缓存和操作系统缓存中没有该域名对应的IP地址记录,则发起DNS查询来获取目标服务器的IP地址。这包括检查本地DNS解析器、向本地DNS服务器请求、递归查询根DNS服务器、顶级域名服务器(TLD)以及权威DNS服务器。
TCP连接
在URL解析过程中得到真实的IP地址之后,会调用Socket函数建立TCP连接。
HTTP请求
浏览器向服务器发起一个 HTTP请求,HTTP协议是建立在TCP协议之上的应用层协议,其本质是建立起的 TCP连接中,按照 HTTP协议标准发送一个索要网页的请求。请求包含请求行、请求头、请求体三个部分组成,有GET、POST等主要方法。
浏览器接收响应
服务器在收到浏览器发送的HTTP请求之后,会将收到的HTTP报文封装成HTTP的Request对象,并通过不同的Web服务器进行处理,处理完的结果以HTTP的Response对象返回,主要包括状态码,响应头,响应报文三个部分。
页面渲染
浏览器根据响应开始显示页面,首先解析 HTML文件构建DOM树,然后解析CSS文件构建渲染树,等到渲染树构建完成后,浏览器开始布局渲染树并将其绘制到屏幕上。
断开连接
客户端和服务器通过四次挥手终止TCP连接。
2、DNS流程
DNS将人类可读的域名转换为计算机网络通信所需的IP地址。
1. 浏览器缓存检查
本地缓存:当用户尝试访问一个网站时,浏览器首先会检查其自身的DNS缓存,看是否已经存储了该域名对应的IP地址。如果有,直接使用该IP地址进行连接,无需进一步查询。
2. 操作系统缓存检查
如果浏览器缓存中没有找到相应的记录,则操作系统会在其DNS缓存中查找。如果找到了匹配项,同样可以直接使用而不必发起新的DNS查询。
3. 查询本地DNS解析器
若上述两个层级的缓存都没有命中,操作系统将向配置的本地DNS解析器发送请求。这个解析器通常是用户的ISP(互联网服务提供商)提供的DNS服务器,或者是用户手动设置的一个公共DNS服务器(如Google DNS、Cloudflare DNS等)。
4. 递归查询(从大往小查,从粗往细查)
查询根域名服务器:本地DNS解析器若未在自己的缓存中找到答案,则会执行递归查询。首先联系根域名服务器(Root DNS Servers)。全球共有13组这样的服务器,它们不直接提供具体的域名到IP地址的映射,而是指向更具体的顶级域名(TLD)服务器。
查询顶级域名服务器(TLD):根据要查询的域名后缀(例如.com、.org),根域名服务器返回负责该TLD的权威DNS服务器的信息。然后,本地DNS解析器继续向这些TLD服务器发出查询。
查询权威域名服务器:TLD服务器返回管理特定域名的权威DNS服务器的地址。最后,本地DNS解析器向这些权威DNS服务器发起最终查询以获取确切的IP地址信息。
5. 返回结果
权威DNS服务器响应本地DNS解析器的查询,提供目标域名对应的IP地址。然后,这个IP地址被传递回给操作系统,并由操作系统转发给应用程序(如浏览器)。
应用程序使用获得的IP地址建立与目标服务器的TCP/IP连接,从而完成整个域名解析过程并开始数据传输。
6. 缓存结果
在上述过程中,每一步得到的结果通常都会被缓存起来,以便于后续相同域名的查询能够快速响应。缓存的时间长度由DNS记录中的TTL(Time To Live)字段决定。
3、TCP和UDP的应用
TCP 的典型应用场景
TCP 是面向连接、可靠、有序 的协议,适用于对数据完整性要求高、需要保证传输可靠性的场景:
-
网页浏览(HTTP/HTTPS)
- 浏览器与服务器之间的页面请求和资源传输(如HTML、图片)需要可靠传输,确保数据不丢失、不乱序。
-
文件传输(FTP、SFTP)
- 文件传输协议(FTP)依赖TCP确保文件内容完整无误地传输,避免数据损坏。
-
电子邮件(SMTP、IMAP/POP3)
- 邮件发送(SMTP)和接收(IMAP/POP3)需要可靠传输,确保邮件内容不丢失。
-
远程登录(SSH、Telnet)
- 远程终端连接(如SSH)需要逐字节的可靠传输,避免指令乱序或丢失。
-
数据库连接(MySQL、PostgreSQL)
- 数据库操作对数据一致性要求极高,TCP的可靠性确保SQL查询和事务的正确执行。
-
即时通讯(微信、QQ消息)
- 文字聊天、文件传输等需要保证消息不丢失且按顺序到达。
UDP 的典型应用场景
UDP 是无连接、不可靠、快速 的协议,适用于对实时性要求高、延迟低、能容忍少量丢包的场景:
-
实时音视频通信(VoIP、直播)
- 如Zoom、Skype的语音通话和视频会议,使用UDP(RTP协议)减少延迟,容忍偶尔的丢包。
- 直播平台(如Twitch、YouTube Live)通过UDP传输实时视频流,避免TCP重传导致的卡顿。
-
在线游戏
- 游戏中的实时位置更新、玩家动作同步(如《王者荣耀》《CS:GO》)使用UDP,低延迟比完美可靠性更重要。
-
DNS查询
- 域名解析通常使用UDP(端口53),因为请求和响应数据包较小,且可以接受偶尔的重试。
-
网络广播/多播
- 如实时股票行情推送、局域网内的流媒体广播(UDP支持一对多传输)。
混合使用场景
某些应用会结合TCP和UDP的优势:
相关文章:
2025/2/25,字节跳动后端开发一面面经
一、双方简单自我介绍 面试官先自我介绍,之后属于面试官看简历过程,基本不听。 二、实习中遇到最难的事情,怎么解决的 主要问的还是实习中做过的项目,项目难点在哪里(自己参与的地方),面对困难是怎么思考,怎么实际操作解决的。 三、项目实现细节 掌握自己项目的实…...
Buildroot 添加自定义模块-内置文件到文件系统
目录 概述实现步骤1. 创建包目录和文件结构2. 配置 Config.in3. 定义 cp_bin_files.mk4. 添加源文件install.shmy.conf 5. 配置与编译 概述 Buildroot 是一个高度可定制和模块化的嵌入式 Linux 构建系统,适用于从简单到复杂的各种嵌入式项目. buildroot的源码中bui…...
SpringBoot新闻推荐系统设计与实现
随着信息时代的快速发展,新闻推荐系统成为用户获取个性化内容的重要工具。本文将介绍一个幽络源的基于SpringBoot开发的新闻推荐系统,该系统功能全面,操作简便,能够满足管理员和用户的多种需求。 管理员模块 管理员模块为系统管…...
领域驱动设计:事件溯源架构简介
概述 事件溯源架构通常由3种应用设计模式组成,分别是:事件驱动(Event Driven),事件溯源(Event Source)、CQRS(读写分离)。这三种应用设计模式常见于领域驱动设计(DDD)中,但它们本身是一种应用设计的思想,不仅仅局限于DDD,每一种模式都可以单独拿出来使用。 E…...
基于Java+Spring+Mybsita+mysql的汽租车辆共享平台的设计源码+设计文档
文末获取源码数据库文档 感兴趣的可以先收藏,有毕设问题,项目以及论文撰写等问题都可以和博主沟通,尽最大努力帮助更多的人! 目录 1软件需求 1.1引言 1.1.1编写目的 1.1.2背景 1.2 绪论 1.2.1-Internet与…...
深度学习的正则化深入探讨
文章目录 一、说明二、学习目标三、什么是机器学习中的正则化四、了解过拟合和欠拟合五、代价函数的意义六、什么是偏差和方差?七、机器学习中的正则化? 一、说明 在训练机器学习模型时,模型很容易过拟合或欠拟合。为了避免这种情况…...
Token相关设计
文章目录 1. 双Token 机制概述1.1 访问令牌(Access Token)1.2 刷新令牌(Refresh Token) 2. 双Token 认证流程3. Spring Boot 具体实现3.1 生成 Token(使用 JWT)3.2 解析 Token3.3 登录接口(返回…...
【时序预测】在线学习:算法选择(从线性模型到深度学习解析)
——如何为动态时序预测匹配最佳增量学习策略? 引言:在线学习的核心价值与挑战 在动态时序预测场景中(如实时交通预测、能源消耗监控),数据以流式(Streaming)形式持续生成,且潜在的…...
React antd的datePicker自定义,封装成组件
一、antd的datePicker自定义 需求:用户需要为日期选择器的每个日期单元格添加一个Tooltip,当鼠标悬停时显示日期、可兑换流量余额和本公会可兑流量。这些数据需要从接口获取。我需要结合之前的代码,确保Tooltip正确显示,并且数据…...
学生管理前端
文章目录 首页student.html查询功能 首页 SpringBoot前端html页面放在static文件夹下:/src/main/resources/static 默认首页为index.html,我们可以用两个超链接或者两个button跳转到对应的页面。这里只是单纯的跳转页面,不需要提交表单等其…...
深入理解并实现自定义 unordered_map 和 unordered_set
亲爱的读者朋友们😃,此文开启知识盛宴与思想碰撞🎉。 快来参与讨论💬,点赞👍、收藏⭐、分享📤,共创活力社区。 在 C 的标准模板库(STL)中,unorder…...
顶顶通呼叫中心中间件(mod_cti基于FreeSWITCH)-大模型电话机器人
语音流直接对接Realtime API 多模态大模型 直接把音频流输出给大模型,大模型返回音频流。 顶顶通CTI对Realtime API 的支持 提供了以下2个APP可对接任意 •cti_audio_stream 通过TCP推流和播放流,适合用于人机对话场景。 •cti_unicast_start 通过旁…...
kinova机械臂绿色灯一闪一闪及刷机方法
一、背景 实验室有两个kinova mico机械臂,但经常出现操纵杆上的绿色灯一闪一闪的,导致无法使用操纵杆或ROS进行控制,下面给出官方的教程以及所需要的FS 0CPP 0008_6.2.5_mico_6dof.hex文件。 重要的东西写在前面: a、如果出现操…...
第16天:C++多线程完全指南 - 从基础到现代并发编程
第16天:C多线程完全指南 - 从基础到现代并发编程 一、多线程基础概念 1. 线程创建与管理(C11) #include <iostream> #include <thread>void hello() {std::cout << "Hello from thread " << std::this_…...
中科大计算机网络原理 1.5 Internt结构和ISP
一、互联网的层次化架构 覆盖范围分层 主干网(Tier-1级) 国家级或行业级核心网络,承担跨区域数据传输和全球互联功能。例如中国的四大主干网(ChinaNET、CERNET等)以及跨国运营商(如AT&T、Deuts…...
Windows安装sql server2017
看了下官网的文档,似乎只有ubuntu18.04可以安装,其他debian系的都不行,还有通过docker的方式安装的。 双击进入下载的ISO,点击执行可执行文件,并选择“是” 不要勾选 警告而已,不必理会 至少勾选这两…...
计算机网络之传输层(tcp协议)
一、TCP协议的特点 面向连接:TCP使用面向连接的通信模式,通信双方需要先建立连接,然后才能进行数据的传输。连接建立过程采用三次握手的方式。 可靠性:TCP提供可靠的数据传输服务,确保数据的完整性、有序性和正确性。…...
从零到一:如何用阿里云百炼和火山引擎搭建专属 AI 助手(DeepSeek)?
本文首发:从零到一:如何用阿里云百炼和火山引擎搭建专属 AI 助手(DeepSeek)? 阿里云百炼和火山引擎都推出了免费的 DeepSeek 模型体验额度,今天我和大家一起搭建一个本地的专属 AI 助手。 阿里云百炼为 …...
Open3D解决SceneWidget加入布局中消失的问题
Open3D解决SceneWidget加入布局中消失的问题 Open3D解决SceneWidget加入布局中消失的问题1. 问题2. 问题代码3. 解决 Open3D解决SceneWidget加入布局中消失的问题 1. 问题 把SceneWidget加到布局管理其中图形可以展示出来,但是鼠标点击就消失了。 stackoverflow上已…...
计算机毕业设计Python+DeepSeek-R1大模型游戏推荐系统 Steam游戏推荐系统 游戏可视化 游戏数据分析(源码+文档+PPT+讲解)
温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 温馨提示:文末有 CSDN 平台官方提供的学长联系方式的名片! 作者简介:Java领…...
Warcraft Helper终极指南:5分钟让你的魔兽争霸3在现代系统流畅运行
Warcraft Helper终极指南:5分钟让你的魔兽争霸3在现代系统流畅运行 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 还在为魔兽争霸3在Wind…...
基于图神经网络的Java空安全注解自动推断技术解析
1. 项目概述:当机器学习遇见类型推断在Java开发中,空指针异常(NullPointerException)堪称“程序员之敌”,它潜伏在代码的各个角落,是运行时崩溃的常见元凶。为了从根源上解决这个问题,可插拔类型…...
比系统自带强在哪?深度体验WizTree v4.16:磁盘分析老手的新选择
WizTree v4.16:重新定义磁盘空间分析的效率革命当你的C盘突然亮起红色警告,或是发现SSD剩余空间以每天1GB的速度神秘消失时,大多数人的第一反应是打开Windows自带的磁盘清理工具。但真正经历过数据洪流洗礼的IT老手,往往会默默启动…...
石墨烯六边形Hubbard模型的量子模拟研究
1. 石墨烯六边形Hubbard模型的量子模拟背景在凝聚态物理研究中,理解强关联电子系统的行为一直是核心挑战。这类系统展现出超导、量子自旋液体等丰富物理现象,而Hubbard模型作为描述电子在晶格中相互作用的最简模型,已成为理论研究的重要工具。…...
保姆级教程:为你的CentOS7服务器手动安装GNOME桌面,告别黑屏与鼠标箭头
从零构建CentOS7图形化工作站:GNOME桌面完整安装与深度优化指南当你第一次面对CentOS7漆黑的命令行界面时,那种茫然无措的感觉我深有体会。三年前接手公司第一台生产服务器时,我盯着闪烁的光标整整十分钟不敢敲下任何命令——毕竟在Ubuntu漂亮…...
非参数贝叶斯聚类与核主成分分析:从原理到工程实践
1. 项目概述:从数据分组到降维的工程实践在数据科学和机器学习的日常工作中,我们常常面临两大核心挑战:一是如何从一堆看似杂乱无章的数据点中,发现其内在的、有意义的组别结构;二是当数据维度高到令人眼花缭乱时&…...
医疗AI可解释性:融合SHAP与反事实解释,破解阿尔茨海默病诊断黑箱
1. 项目概述:为什么阿尔茨海默病诊断需要“看得懂”的AI?在神经退行性疾病诊断领域,尤其是阿尔茨海默病(AD)和轻度认知障碍(MCI),机器学习模型已经展现出超越传统统计方法的潜力。然…...
从零到一:用 LangChain 搭建你的第一个 AI Agent,让 LLM 自己干活!
导读:,2024年最火的不是大模型本身,而是基于大模型的 AI Agent。它能自主思考、调用工具、执行任务——不再是"你说一句我回一句"的聊天机器人,而是真正能帮你干活的数字员工。本文从零带你搭建一个完整的 AI Agent&…...
边缘计算赋能触觉互联网与数字孪生:架构、挑战与物理治疗实践
1. 从概念到现实:边缘计算如何重塑触觉互联网与人类数字孪生在远程医疗、工业操控乃至未来的元宇宙体验中,我们一直梦想着能突破屏幕的界限,实现“隔空取物”般的真实交互。医生希望远程为病人进行精准的物理治疗,工程师渴望在千里…...
告别K-means!用DBSCAN搞定雷达点云聚类,手把手教你调参(附Matlab代码)
毫米波雷达点云聚类的DBSCAN实战:从算法原理到参数调优 在自动驾驶和智能交通系统中,毫米波雷达因其全天候工作能力和稳定的测距测速性能,成为不可或缺的环境感知传感器。然而,原始雷达数据往往呈现为稀疏、噪声密集且分布不规则的…...
