2018秋招面经-后端开发

2017年11月08日 15:37:15

博主渣渣本科,挣扎到十一月秋招终于结束了。面过百度/腾讯/小米/网易/搜狗/知乎/京东/360/瓜子。期间总结了一些面试题目,现在放上来。由于是博主自己的面经记录,所以涵盖不全面的话诸位请谅解。
根据博主的面试经验来看,面试有一定的层次性,如bat级别公司每个点都会深入,而有些公司则只会问到表层,所以将每个领域都分为必须掌握和深入了解这两个部分。

一、计算机网络

基础部分

  1. TCP报头格式
  2. UDP报头格式
  3. TCP/UDP区别(不仅是宏观上的,最好能根据各自的机制讲解清楚)
  4. HTTP状态码(最好结合使用场景,比如在缓存命中时使用哪个)
  5. HTTP协议(一些报头字段的作用,如cace-control、keep-alive)
  6. OSI协议、TCP/IP协议以及每层对应的协议。
  7. SESSION机制、cookie机制
  8. TCP三次握手、四次挥手(这个问题真的要回答吐了,不过真的是面试官最喜欢问的,建议每天手撸一遍,而且不只是每次请求的过程,各种FIN_WAIT、TIME_WAIT状态也要掌握)。
  9. 打开网页到页面显示之间的过程(涵盖了各个方面,DNS解析过程,Nginx请求转发、连接建立和保持过程、浏览器内容渲染过程,考虑的越详细越好)。
  10. http和https区别,https在请求时额外的过程,https是如何保证数据安全的
  11. IP地址子网划分
  12. POST和GET区别
  13. DNS解析过程

深入部分
13. TCP如何保证数据的可靠传输的(这个问题可以引申出很多子问题,拥塞控制慢开始、拥塞避免、快重传、滑动窗口协议、停止等待协议、超时重传机制,最好都能掌握)
14. 地址解析协议ARP
15. 交换机和路由器的区别

二、数据库

基础部分

  1. 事务四大特性(ACID)
  2. 数据库隔离级别,每个级别会引发什么问题,mysql默认是哪个级别
  3. MYSQL的两种存储引擎区别(事务、锁级别等等),各自的适用场景
  4. 数据库的优化(从sql语句优化和索引两个部分回答)
  5. 索引有B+索引和hash索引,各自的区别
  6. B+索引数据结构,和B树的区别
  7. 索引的分类(主键索引、唯一索引),最左前缀原则,哪些情况索引会失效
  8. 聚集索引和非聚集索引区别。
  9. 有哪些锁(乐观锁悲观锁),select时怎么加排它锁
  10. 关系型数据库和非关系型数据库区别
  11. 了解nosql
  12. 数据库三范式,根据某个场景设计数据表(可以通过手绘ER图)
  13. 数据库的主从复制
  14. 使用explain优化sql和索引
  15. long_query怎么解决
  16. 内连接、外连接、交叉连接、笛卡儿积等

深入

  1. MVCC机制
  2. 根据具体场景,说明版本控制机制
  3. 死锁怎么解决
  4. varchar和char的使用场景。
  5. mysql并发情况下怎么解决(通过事务、隔离级别、锁)

Redis

  1. redis数据结构有哪些
  2. redis队列应用场景
  3. redis和Memcached(支持数据持久化)
  4. 分布式使用场景(储存session等)
  5. 发布/订阅使用场景

三、操作系统

  1. 内存的页面置换算法
  2. 进程调度算法
  3. 进程间通信方式
  4. 进程线程区别
  5. 进程之间的通信
  6. 父子进程、孤儿进程
  7. fork进程时的操作,
    这个部分我回答的都不好,只能是死记硬背,建议基础好的同学多看看操作系统这部分,能大大加分。

四、算法

基础

  1. 剑指OFFER的各个题目是最常见的,即使不是原题也是题目的变体,因为面试不像笔试,一般不会出特别困难的题目,所以剑指OFFER上小而精的题目就非常适合。建议手刷一遍。PHP的同学可以参考专栏剑指OFFER
  2. 二叉树相关(层次遍历、求深度、求两个节点距离、翻转二叉树、前中后序遍历)
  3. 链表相关(插入节点、链表逆置、使用链表进行大数字的加减,双向链表实现队列、寻找链表中的环)
  4. 堆(大量数据中寻找最大N个数字几乎每次都会问,还有堆在插入时进行的调整)
  5. 排序(八大排序,各自的时间复杂度、排序算法的稳定性。快排几乎每次都问)
  6. 二分查找(一般会深入,如寻找数组总和为K的两个数字)
  7. 两个栈实现队列。
  8. 图(深度广度优先遍历、单源最短路径、最小生成树)
  9. 动态规划问题。

    深入

  10. 红黑树性质

  11. 分治法和动态规划的区别
  12. 计算时间复杂度
  13. 二叉树和哈希表查找的时间复杂度

具体题目记录
1. 一个文本文件中每一行中有一个URL,最多一万行,统计每一个URL的次数,输出到另外一个文件中,每一行前面是URL,后面是个数。
2. 单链表的逆序
3. 一个函数实现给定字符串,去除前面和后面的空格,比如“ ab cd ”,最后得到的结果是”ab cd”,不能改变字符串的地址。
4. 对比cookie和session,有一个值错误则不正确
5. 查找10的阶乘后面有几个0
6. 字符串匹配
7. 字符串移位,给出字符串abc##dfg##gh,实现将所有#移至字符串串头。输出####abcdfggh(个人认为可以用后向移位,减少移位次数)
8. 给出一颗二叉树,两个叶节点,找到这两个叶节点互连通的一条最短路径。
9. 两个日期计算天数差
10. 100个有序数组合并
11. 矩阵的最大子矩阵和
12. 给定一棵多叉树,每个节点有一个编号,现在要对节点排序,要求对于每个节点,它的父节点排在它后面,如果一棵树有N个节点,那么肯定有N-1条边。输入的数据形式为:Map.Entry

LINUX

  1. 硬链接和软连接区别
  2. kill用法,某个进程杀不掉的原因(进入内核态,忽略kill信号)
  3. linux用过的命令
  4. 系统管理命令(如查看内存使用、网络情况)
  5. 管道的使用 |
  6. grep的使用,一定要掌握,每次都会问在文件中查找
  7. shell脚本
  8. find命令
  9. awk使用

语言部分(PHP)

  1. 数组操作函数
  2. 字符串操作函数(数组和字符串的函数是最常问的,非常多,一定不要记混了)
  3. 指针和引用区别
  4. 堆和栈的区别
  5. == ===区别
  6. PHP的垃圾回收机制
  7. zval结构
  8. 防sql注入
  9. 跨域问题
  10. 长链接和长轮询

面向对象、设计模式

  1. 接口和抽象类区别
  2. 单继承
  3. construct的调用顺序(子类父类之间)
  4. 设计模式(工厂模式、策略模式、单例模式、装饰模式比较常见)
  5. OOP特性,通过哪些机制实现的
  6. 重写和重载区别
  7. 静态类静态方法
  8. 根据某个需求设计一个类(主要考虑类之间的继承关系和属性的权限设置)

项目

  1. 项目中遇到的困难(提前想好,并且把实现或者优化方法说清楚)
  2. 系统的量级、pv、uv等
  3. 应对高并发的解决办法(分布式)
  4. 在项目中主要负责了哪些工作。
  5. nginx的负载均衡
  6. 分布式缓存的一致性,服务器如何扩容(哈希环)
  7. 项目中用到了哪些技术
  8. 服务器性能如何测试
  9. 项目中印象深刻的东西
  10. 项目中遇到过哪些坑,怎么解决的
  11. 项目中为什么用redis以及怎么实现相关功能
  12. 用过的开源框架(路由问题),框架的原理
  13. 消息队列的应用场景(想一个)
  14. 有没有用到非关系型数据库
  15. 网站负载变大时怎么办
  16. SOA?
  17. WebService?
  18. 《大型网站技术架构:核心原理与案例分析》
  19. redis的消息队列 redis的数据类型
  20. OAuth认证过程
  21. 单点登陆系统 分布式缓存的使用场景
  22. 一个Controller调用两个Service,这两Service又都分别调用两个Dao,问其中用到了几个数据库连接池的连接?
  23. 图片是怎么存储的
  24. 分布式一致性协议、分布式锁(应用场景)
  25. 项目中的网络编程
  26. 划一下项目的架构
  27. MVC的路由机制怎么实现的(路由很重要)
  28. 为什么要用hadoop
  29. 自己写的接口如何防止被别人恶意调用?印象笔记
  30. 如何实现数据容灾,
  31. 怎样实现负载均衡
  32. 如何解决单节点负载过
  33. Redis和memcache区别
  34. redis的持久化

总之要把写在简历上的项目部分熟悉一遍,技术栈、项目功能、难点都要考虑好。

总结

秋招真的是一场旷日持久的战争,祝各位都能拿到想要的OFFER。

PS:之前把一些难点找到答案做成了PDF,放在手机上每天看一点,效果不错。还有ANKI这个工具对于复习效果也很好。

2017.11.14 PPS:无语了。CSDN把积分提高成11了,我自己不能修改,大家可以私信/留下邮箱吧。那些用11积分下载的同学实在抱歉

2017.11.10 PDF更新了一下,之前通过资源下载的私信我邮箱给你发过去哈。留邮箱的小伙伴我都补充上了

2017校招 美团笔试题 编程题 层次遍历多叉树

题目:美团笔试题 编程题  层次遍历多叉树 给定一棵多叉树,每个节点保存一个int类型数字且节点数字不重复, 要求从上到下按层次打印每个节点的数字,每个层次按从左到右的顺序。  要求:  (1...
  • wolf_fang
  • wolf_fang
  • 2016年09月25日 10:38
  • 948

详解HTTPS是如何确保安全性的?

来自: Android梦想特工队 作者: Aaron 主页: http://www.wxtlife.com/ 原文连接: http://www.wxtlife.com/2016/03/2...
  • wx_962464
  • wx_962464
  • 2016年04月02日 11:03
  • 7662

2017年最新前端工程师面试题整理

1.position的值,relative和absolute分别是相对于谁进行定位的? absolute: 生成绝对定位的元素,相对于最近一级的定位不是static的父元素来进行定位。 fixed...
  • github_38383183
  • github_38383183
  • 2017年05月15日 20:20
  • 1033

后端开发面试题

后端开发面试题 =================== 转自https://raw.githubusercontent.com/Tangxuguo/software-developer-questio...
  • ac_dao_di
  • ac_dao_di
  • 2016年10月05日 19:59
  • 2670

美团2017笔试题 给定一颗多叉树

给定一刻多叉树,每个节点保存一个int类型数字且节点数字不重复,要求从上到下按层次打印每个节点的数字,每一层按从左到右的顺序。 要求: (1)实现一颗多叉树 (2)根据自定义输入,构造多叉树 ...
  • QiangLi_strong
  • QiangLi_strong
  • 2016年10月06日 18:33
  • 565

2018秋招面经——C++后端

某不知名二本财经院校秋招辛酸史。。。。9.17(16:20) 先锋商泰一面:(C++开发) 上海微盟 百度作业帮 土巴兔 小米...
  • wyq_5
  • wyq_5
  • 2017年11月30日 17:08
  • 50

2017年前端面试题整理汇总100题

2017年前端面试题整理汇总100题
  • kebi007
  • kebi007
  • 2017年02月05日 18:14
  • 112272

2017前端面试题及答案总结(一)

1:为何选择前端这个方向和对前端的理解为什么: 第一的话就是对前端很感兴趣,之前也接触过其他的语言,但是直到接触到前端才发现真的有兴趣做下去,兴趣是一个人最好的老师, 第二的话前端很有前途...
  • u013594331
  • u013594331
  • 2017年09月07日 19:00
  • 390

2018秋招-阿里内推编程题

阿里巴巴的ODPS大数据处理平台可以启动一系列并发的作业,每个作业中存在一系列存在父子关系的任务。每个任务用一个三元组表示–(任务id,父任务id,执行开销),其中任务id是一个正整数(>0);父任务...
  • u011296485
  • u011296485
  • 2017年07月06日 20:38
  • 1576

2018秋招面经

先锋商泰,yy,盛大游戏,土巴兔,网龙,好未来,上海微盟等面经
  • wyq_5
  • wyq_5
  • 2017年11月01日 22:09
  • 15
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:2018秋招面经-后端开发
举报原因:
原因补充:

(最多只允许输入30个字)