猿辅导服务器开发上岸
服务器开发岗位
一面
epoll和poll、select的区别
进程、线程、协程
Reactor和Proactor
伙伴系统
数据库会不会 不会,尽量别问
malloc函数的实现
new和malloc的区别
流量控制、拥塞控制
HTTP状态码
TCP如何实现可靠连接
为什么是四次握手
还有一些忘记了,都挺基础的
算法:
1.将一个链表拆分成内容为奇数和偶数的两个链表,不能创建新的节点,只能通过移动的方式。
2.一颗二叉树,只有0、1两种值,从二叉树中删除一些节点,满足是叶子节点并且值为0,比如0的左右子树都为0,那么删完左右子树节点之后,父节点这个0也要删除。
二面:
说说堆和你说的那个时间轮定时器的区别
线程有哪些状态
vector的优势
vector和list的区别
怎么引起死锁的,如何避免
https的实现
对称加密和非对称加密,各自的使用场景
数字证书的生成
熟悉的linux命令
还有几个操作系统的知识点想不起来了
算法:
1.判断一颗树是否是完全二叉树
2.和最大的最长子数组,返回最大值,首尾位置
三面:
项目详细介绍,扣的很细
如何实现一个线程池
计算机网络熟悉哪些地方
流量控制和拥塞控制
为什么是三次握手
为什么管道只能用于有亲缘关系的进程之间
为什么要划分初始化的全局变量和未初始化的全局变量
进程的地址空间,线程如何共享进程的栈空间
算法:
split函数的实现
总结
面试内容很基础,感觉需要自己在表达的时候说点与众不同的地方
#猿辅导##面经##校招##C++工程师#