粥里有勺糖

vuePress-theme-reco 粥里有勺糖    2018 - 2023
粥里有勺糖 粥里有勺糖

Choose mode

  • dark
  • auto
  • light
关于我
备战春秋
  • 心得总结
  • 校招考点汇总
  • 面经汇总
  • 复习自查
技术笔记
  • 技术教程
  • 模板工程
  • 源码学习
  • 技术概念
  • 个人作品
  • 学习笔记
计算机基础
  • 算法与数据结构
  • 操作系统
  • 计算机网络
  • 设计模式
  • 剑指offer
大前端
  • javascript
  • vue
  • html
  • css
  • 🌏浏览器专题
  • Web性能优化
  • regexp
  • node
面试
  • 问解
  • javascript
  • css
  • 手撕代码
  • 性能优化
  • 综合问题
  • 面经汇总
  • 小程序
手撕代码
  • 数据结构与算法
  • javascript
  • css
个人站点
  • GitHub (opens new window)
  • 博客园 (opens new window)
  • 掘金 (opens new window)
线上作品
  • 轻取(文件收集) (opens new window)
  • 个人图床 (opens new window)
  • 考勤小程序 (opens new window)
  • 时光恋人 (opens new window)
  • 在线简历生成 (opens new window)
留言板
Github (opens new window)
author-avatar

粥里有勺糖

285

文章

40

标签

关于我
备战春秋
  • 心得总结
  • 校招考点汇总
  • 面经汇总
  • 复习自查
技术笔记
  • 技术教程
  • 模板工程
  • 源码学习
  • 技术概念
  • 个人作品
  • 学习笔记
计算机基础
  • 算法与数据结构
  • 操作系统
  • 计算机网络
  • 设计模式
  • 剑指offer
大前端
  • javascript
  • vue
  • html
  • css
  • 🌏浏览器专题
  • Web性能优化
  • regexp
  • node
面试
  • 问解
  • javascript
  • css
  • 手撕代码
  • 性能优化
  • 综合问题
  • 面经汇总
  • 小程序
手撕代码
  • 数据结构与算法
  • javascript
  • css
个人站点
  • GitHub (opens new window)
  • 博客园 (opens new window)
  • 掘金 (opens new window)
线上作品
  • 轻取(文件收集) (opens new window)
  • 个人图床 (opens new window)
  • 考勤小程序 (opens new window)
  • 时光恋人 (opens new window)
  • 在线简历生成 (opens new window)
留言板
Github (opens new window)
  • 校招面经汇总

    • 校招面经汇总
    • 20年秋招
      • B站-主站技术中心
      • 字节跳动-商业变现-广告
      • 网易-云音乐
      • 快手-最大的前端团队
      • 牛客网-大前端团队
      • shopee-供应链
      • 腾讯-腾讯云
      • 作业帮-前端团队
    • 20年春招
      • 百度-百度文库
      • 字节跳动-飞书
      • 快手-Acfun
      • 美团-到店事业群
      • 蘑菇街-小程序BU
      • 腾讯-腾讯看点
      • 腾讯-腾讯视频
      • thoughtWorks-思特沃克
      • 网易互娱
      • 网易-云音乐
    • 21年春招
      • 字节跳动-抖音架构
    • 22年春招
      • 字节
      • 成都某公司
      • 滴滴国际化
      • 滴滴-效能平台
      • 字节飞书
      • 搜狐焦点
      • 微多多
      • 网易传媒

腾讯-腾讯看点

vuePress-theme-reco 粥里有勺糖    2018 - 2023

腾讯-腾讯看点

粥里有勺糖 2020-10-23 备战春秋2020春招

# 腾讯-腾讯看点

# 一面

和面试官电话聊了差不多20分钟,个人介绍,学习经历,项目经历,实习经历四个方面

然后面试官发了一套题过来,开屏幕分享做,差不多2.5小时做完

# 手撕代码部分

1.给定数组如下,请根据数组元素的age字段对数组排序,多种实现方式可加分

const a = [
    {
        name: '大毛',
        age: 12,
    },
    {
        name: '二毛',
        age: 34,
    },
    {
        name: '三毛',
        age: 23,
    }
];
// 我写了三种
// Array.sort
// 冒泡排序O(N2)
// 快速排序O(N*logN)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
  1. 拦截 console.log 在用户传入,并且在用户输入前打印几个字符串
输入:console.log('Hello', 'World');
输出:xxx Hello-World
1
2

我的解法利用Object.defineProperty与闭包

(function () {
    const log = console.log
    Object.defineProperty(console, 'log', {
        configurable: true,
        value: function (...arg) {
            log('自定义内容xxx', arg.join('-'));
        }
    })
})()

console.log('hello', 'world')
1
2
3
4
5
6
7
8
9
10
11
  1. 实现调用闭包函数,使每调用一次返回值都会加1
const func = (function () {
// TODO 请实现对应代码逻辑

})();
console.log(func()); // -> 1
console.log(func()); // -> 2
console.log(func()); // -> 3
1
2
3
4
5
6
7
  1. 编写代码判断两个日期是否是同一周(可使用MDN查询JS相关日期函数)
function isSameWeek (d1: Date, d2: Date): boolean {
// TODO,已知 d2 > d1, 按照周一是一周的第一天的逻辑来算,请实现对应的代码
}
console.log(isSameWeek(new Date('2019-09-28'), new Date('2019-09-29')));   // true
console.log(isSameWeek(new Date('2019-09-29'), new Date('2019-09-30')));   // false
1
2
3
4
5
  1. 给定一个大小为n的数组,找到其中的多数元素
多数元素是指在数组中出现次数大于n/2的元素
如输入[3,2,3]输出3,输入[2,2,1,1,1,2,2]输出2,多种实现方式可加分。
1
2
  1. 汽水2元1瓶,每3个空瓶可换1瓶汽水,请用代码实现输入任意整数金额,输出可喝多少瓶汽水

  2. 通过键盘输入一串小写字母(a~z)组成的字符串,请编写一个字符串压缩程序

将字符串中连续出现的重复字母进行压缩,并输出压缩后的字符串

压缩规则:
a. 仅压缩连续重复出现的字符。比如字符串"abcbc"由于无连续重复字符,压缩后的字符串还是"abcbc"。
b. 压缩字段的格式为"字符重复的次数+字符"。例如:字符串"xxxyyyyyyz"压缩后就成为"3x6yz"。
1
2
3
4
5
  1. 输入一个矩阵m*n,按照从外向里以顺时针的顺序依次扫印出每一个数字
input:
[
[1, 4, 7],
[2, 5, 8],
[3, 6, 9],
]
output:
1 4 7 8 9 6 3 2 5
1
2
3
4
5
6
7
8
  1. 写一个程序按箭头顺序在下面矩阵中填入对应数据 图片

# 问答题

  1. 对于日均PV百亿级的页面(即访问量巨大),想要设计系统扛住流量,简述各环节(不局限于前端)上可以做哪些措施
  2. 进程的调度算法有哪些?请分别简述
  3. TCP三次握手的目的是什么?服务端为什么要回传SYN和ACK?客户端收到后为什么要回传ACK?

# 智力题

一间囚房里关押着两个犯人。每天监狱都会为这间囚房提供一罐汤,让这两个犯人自己来分。起初,这两个人经常会发生争执,因为他们总是有人认为对方的汤比自己的多。后来他们找到了一个两全其美的办法:一个人分汤,让另一个人先选。于是争端就这么解决了。可是,现在这间囚房里又加进来一个新犯人,现在是三个人来分汤。必须寻找一个新的方法来维持他们之间的和平。该怎么办呢?
1

# 二面

# 项目

  1. 项目经验
  2. 项目中的难点有哪些,是如何解决的

# node

  1. 用过node吗
  2. 了解koa与express的区别在哪里吗

# 计网

  1. http2的特点有哪些
  2. 简单说一下https?它是安全的吗
  3. 说一下TLS协议的工作流程

# 浏览器

  1. 了解浏览器安全吗?说一下有哪些安全隐患和如何预防

# 技术基本功

  1. 对前端工程化有没有实践过
  2. TS与JS的区别
  3. 会用Git吗?说说常用的几个命令

# 其它

  1. 最近在学什么
  2. 平时怎么学习的
  3. 为什么选择前端而不是后端
Edit this page (opens new window)
Last Updated: 2022/5/15 12:46:34