百度+阿里+腾讯+笔试题目(2020届)

这篇博客回顾了作者在2020届校招期间参加百度、阿里和腾讯的笔试及面试经历。百度的面试让作者印象深刻,头条的算法题目难度极高,涉及到LFU缓存策略。阿里面试轮次多,达到了6轮,而腾讯的面试涵盖了C++基础、操作系统、TCP网络、数据结构与算法等方面的知识。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

百度度秘事业部
百度是我第一家面试的公司,而且还是bat的大厂级别,那时的我也不知道自己啥水平,接到面试电话慌的不行,面试第一次非常难忘。下午3点,面试40分钟!

百度一面:

1、实验室项目里面使用什么建模的

2、进程和线程具体的区别

3、协程

4、ngnix高性能服务器,为啥高性能

5、输入一个URL,如何显示页面的过程

6、TCP三次握手

7、为什么需要三次握手

8、Time_wait

9、什么是TCP粘包

10、网络模型分几个层次

11、TCP,UDP的区别

12、流量控制和拥塞控制的区别

13、TCP出现在传输层,IP在网络层

14、什么是平衡二叉树

15、快速排序和堆排序,什么是稳定和不稳定

16、单链表如何判断有环?环的位置在哪?

17、你来实习能实习多久?

18、部门做啥的,DuerOS,人工智能操作系统,度秘事业部。

百度二面:

1、TCP协议和IP协议有什么关系

2、TCP是如何保证可靠传输的

3、是如何确认的

4、发送端是如何确认需要重传哪些包的

5、TCP和HTTP的关系,HTTP还可以基于什么传输

6、HTTP和HTTPS的关系

7、加密算法有哪些,如何理解MD5

8、Linux如何创建空文件,创建目录指令,find如何查找用户名为work的文件,(答的不好)

9、如何调试的,GDB调试,

10、GDB如何打印当前进程的堆栈-(gdb) bt

11、如何将当前客户端的内容发送给其他客户端,如何实现的。

12、同时发消息,是以什么顺序发送给其他人的

13、同时有一万人,同时说一句话,服务器没法处理的,该怎么办

14、短连接和长连接,聊天室是采取哪种连接方式。

15、那你的聊天室采用短连接,连接的客户端又断开了,那你怎么发送数据给其他客户端的。

16、实验室项目介绍。

17、你有什么问题问我。

头条IES抖音部门
头条的面试效率贼高,一周offer!面试的算法题是最难的,变态那种,LFU !

阿里云
发现就记录了两轮面试的记录,其他的还是合在一起吧。其实一直没对阿里报太大希望,拿到头条offer了,很佛系,管你那么多,面得过就去,面不过就拉倒,感觉有了一个offer之后,自己就可以稳中带皮的面试,哈哈~~不过阿里的面试轮次非常多,居然面了6轮,太累。得知交叉面的时候,感觉也是很震惊,自己评级居然还挺高。

阿里巴巴二面:

1、介绍一下web服务器的架构和实现(语速慢点)

2、智能指针(等面试官说完话在回答)

3、http里面列举几个消息头,最常用的消息头。

4、为什么不使用多进程形式?

5、nginx

6、get文件返回和二进制文件返回有什么区别

7、主进程和工作线程中,epoll对套接字的复用是如何做的。

8、线程的套接字和主进程的套接字是如何作用的

9、华为挑战赛讲一下,做了多久。

10、实验室项目,技术层面上讲

11、做题目多线程归并排序

阿里交叉二面:

1、项目遇到什么问题

2、介绍智能指针,weak_ptr一般怎么使用?

3、项目实现了HTTP的GET方法,有办法可以拓展到实现POST方法吗?

4、GET和POST幂等性,为什么POST不幂等?

5、POST可以获取数据吗?

6、聊天室程序有何问题?

7、分离读写流?为什么采用父子进程?应该是并行关系(这个不好,最好删掉)

8、实验室项目的介绍?具体做了什么东西?

9、如何衡量疏散预案的好坏的?

10、你有什么问题问我吗?

腾讯IEG一面

1、UTF8和GD2312的区别

2、一个汉字在GD2312中是几个字节表示的

3、Linux进程栈和堆的空间如何分配和释放的

4、进程栈和线程栈的区别

5、线程栈是在哪里分配的

6、TCP是如何处理粘包的问题

7、malloc的内存分配方式

8、二叉树找公共祖先,只有root节点和两个节点指针。

9、无序的整数数组,使得奇数在前面,所有的偶数都在后面。

1 C++基础:

指针失效问题如何解决?
全局变量和静态变量
智能指针
emplace / empalce_front / emplace_back
面向对象的?面向对象的特性?有什么优点,比面向过程的语言好在哪?
· 模板特化
· 定位内存泄露
C语言是怎么进行函数调用的?
C语言参数压栈顺序?
C语言如何处理返回值?

2 操作系统

命名管道和无名管道
堆栈溢出
进程和线程
守护进程、僵尸进程、孤儿进程,守护进程的作用是什么?
· 协程
一个文件被删除了,没有被释放是什么原因呢?
弱类型、强类型、动态类型是什么
自旋锁
进程栈和线程栈的区别
· OPEN的过程
READ的过程
WRITE的过程
操作系统是如何调度进程呢
消息队列
· malloc函数具体实现原理
死锁的原因?条件?如何预防?又如何避免?如何解除?
伙伴算法和slab算法
线程是如何绑定到具体的cpu
什么是绑核?实现方式?
进程的调度算法

3 TCP网络

概率题
假设一段公路上,1小时内有汽车经过的概率为96%,那么,30分钟内有汽车经过的概率为?

字节序与网络字节序
超时重传、快速重传
客户端服务器通信死锁如何处理?
长连接和短连接
1) HTTP协议与TCP/IP协议的关系

2) 如何理解HTTP协议是无状态的

3)什么是长连接、短连接?

4)TCP协议的长连接和短连接优点和缺点

· 什么是MD5?
· 阻塞式IO使用场景
· 什么是TCP粘包
· 拒绝服务攻击DOS
XSS,SQL
· HTTPS建立连接的过程
常用的HTTP请求头与响应头
HTTP请求头:

HTTP响应头:

TCP是如何保证有序传输的?

拥塞控制的改进
· POST可以获取数据吗?就是实现GET方法?

4 数据结构与算法:

堆排序和快速排序 or 快排为什么快呢?
哈希表如何设计?需要利用到磁盘空间。
STL中hash_map扩容发生什么?

5 项目

同时有一万人,同时说一句话,服务器没法处理的,该怎么办?
高并发的解决方法
如何热启动服务器?

6 其他知识

UTF8和GD2312的区别
微信PC版,扫码登录是怎么做的?
C++多线程对10个文件进行排序
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

N1314N

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值