前端开发实习,96道前端面试题

计算机网络篇

HTTP

  • HTTP 报文结构是怎样的?
  • HTTP有哪些请求方法?
  • GET 和 POST 有什么区别?
  • 如何理解 URI?
  • 如何理解 HTTP 状态码?
  • 简要概括一下 HTTP 的特点和缺点?
  • 对 Accept 系列字段了解多少?
  • 对于定长和不定长的数据,HTTP 是怎么传输的?
  • HTTP 如何处理大文件的传输?
  • HTTP 中如何处理表单数据的提交?
  • HTTP1.1 如何解决 HTTP 的队头阻塞问题?
  • 对 Cookie 了解多少?
  • 如何理解 HTTP 缓存及缓存代理?
  • 为什么产生代理缓存?
  • 源服务器的缓存控制
  • 客户端的缓存控制
  • 什么是跨域?浏览器如何拦截响应?如何解决?
  • TLS1.2 握手的过程是怎样的?
  • 传统 RSA 握手
  • RSA 和 ECDHE 握手过程的区别
  • TLS 1.3 做了哪些改进?
  • HTTP/2 有哪些改进?
  • HTTP/2 中的二进制帧是如何设计的?

TCP协议

  • TCP 和 UDP 的区别?
  • TCP 三次握手的过程?
  • 为什么是三次而不是两次、四次?
  • 三次握手过程中可以携带数据么?
  • 说说 TCP 四次挥手的过程
  • 为什么是四次挥手而不是三次?
  • 半连接队列和 SYN Flood 攻击的关系
  • 如何应对 SYN Flood 攻击?
  • 介绍一下 TCP 报文头部的字段
  • TCP 快速打开的原理(TFO)
  • 说说TCP报文中时间戳的作用?
  • TCP 的超时重传时间是如何计算的?
  • TCP 的流量控制
  • TCP 的拥塞控制
  • 说说 Nagle 算法和延迟确认?
  • 如何理解 TCP 的 keep-alive?

浏览器篇

  • 浏览器缓存?
  • 说一说浏览器的本地存储?各自优劣如何?
  • 说一说从输入URL到页面呈现发生了什么?
  • 谈谈你对重绘和回流的理解
  • XSS攻击
  • CSRF攻击
  • HTTPS为什么让数据传输更安全?
  • 实现事件的防抖和节流?
  • 实现图片懒加载?

数据结构和算法

链表

  • 简单的反转链表
  • 区间反转
  • 两个一组翻转链表
  • K个一组翻转链表
  • 如何检测链表形成环?
  • 如何找到环的起点
  • 合并两个有序链表
  • 合并 K 个有序链表
  • 判断回文链表

栈和队列

  • 有效括号
  • 多维数组 flatten
  • 普通的层次遍历
  • 二叉树的锯齿形层次遍历
  • 二叉树的右视图
  • 完全平方数
  • 单词接龙
  • 优先队列
  • 关于堆的说明
  • 实现一个最大堆
  • 实现优先队列
  • 前 K 个高频元素
  • 合并 K 个排序链表
  • 什么是双端队列?
  • 滑动窗口最大值
  • 栈实现队列
  • 队列实现栈

二叉树

  • 遍历
  • 给定一个二叉树,找出其最大深度
  • 给定一个二叉树,找出其最小深度
  • 对称二叉树
  • 二叉树的最近公共祖先
  • 二叉搜索树的最近公共祖先
  • 二叉树的直径
  • 二叉树的所有路径
  • 二叉树的最大路径和
  • 将有序数组转换为二叉搜索树
  • 二叉树展开为链表
  • 不同的二叉搜索树II

总结

写到这里,希望读者把本文提出的这几个问题,经过深刻的准备后,一般来说,能囊括大部分的消息队列的知识点。

如果面试官不问这几个问题怎么办,简单,自己把几个问题讲清楚,突出以下自己考虑的全面性。

最后,其实我不太提倡这样突击复习,希望大家打好基本功,做一个爱思考,懂思考,会思考的程序员。

题,经过深刻的准备后,一般来说,能囊括大部分的消息队列的知识点。

如果面试官不问这几个问题怎么办,简单,自己把几个问题讲清楚,突出以下自己考虑的全面性。

最后,其实我不太提倡这样突击复习,希望大家打好基本功,做一个爱思考,懂思考,会思考的程序员。

你可能感兴趣的:(程序员,面试,前端,大前端)