商务服务
九道新鲜出炉的大厂面试题,嗯,有点意思(1),2024年最新面试突击 百度网盘
2024-10-31 17:56

先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7

九道新鲜出炉的大厂面试题,嗯,有点意思(1),2024年最新面试突击 百度网盘

深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前

因此收集整理了一份《2024年最新Web前端全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上前端开发知识点,真正体系化

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

如果你需要这些资料,可以添加V获取:vip1024c (备注前端
img

正文

console.time();

let a = wait();

let b = wait();

let c = wait();

await a;

await b;

await c;

console.timeEnd();

main();

这个的运行时间是10s多一点,这是因为:a,b,c的异步请求会按顺序发起。而这个过程是不需要互相依赖等待的。等到wait的时候,其实是比较那个异步耗时最多。就会等待最长。最长的耗时就是整体的耗时。

如果在业务中,两个异步没有依赖关系。应该是后面这种写法。

第 2 题:接口如何防刷

============

解析:去了京东、腾讯、虾皮等厂子都问到了这个问题。

我们之前也遇到过,基本就是后端工程师限制用户的接口调用次数,面试官希望可以有更多的答案。

1:网关控制流量洪峰,对在一个时间段内出现流量异常,可以拒绝请求

2:源请求个数限制。对请求来源的请求个数做限制

3:请求头信息校验(例如

4:对用户唯一身份uid进行限制和校验。例如基本的长度,组合方式,甚至有效性进行判断。或者uid具有一定的时效性

5:前后端协议采用二进制方式进行交互或者协议采用签名机制

6:人机验证,验证码,短信验证码,滑动图片形式,12306形式

第 3 题:用 setTimeout 实现 setInterval,阐述实现的效果与 setInterval 的差异

function mySetInterval() {

mySetInterval.timer = setTimeout(() => {

arguments0

mySetInterval(…arguments)

}, arguments[1])

mySetInterval.clear = function() {

clearTimeout(mySetInterval.timer)

mySetInterval(() => {

console.log(11111)

}, 1000)

setTimeout(() => {

// 5s 后清理

mySetInterval.clear()

}, 5000)

第 4题:webpack 打包 vue 速度太慢怎么办

============================

说说我的处理方式吧,纯经验之谈

1.使用对项目进行模块分析生成report,查看report后看看哪些模块体积过大,然后针对性优化,比如我项目中引用了常用的UI库element-ui和v-charts等

2.配置webpack的 ,官方文档的解释:防止将某些的包(package)打包到 bundle 中,而是在运行时(runtime)再去从外部获取这些扩展依赖。

所以,可以将体积大的库分离出来

// …

externals: {

‘element-ui’: ‘Element’,

‘v-charts’: ‘VCharts’

3.然后在中移除相关库的import

4.在模板文件中,添加相关库的引用,如

经过以上的处理,再尝试编译打包,会发现速度快了一些。

第 5 题:为什么for循环嵌套顺序会影响性能

var t1 = new Date().getTime()

for (let i = 0; i < 100; i++) {

for (let k = 0; k < 10000; k++) {

var t2 = new Date().getTime()

console.log(‘first time’, t2 - t1)

for (let i = 0; i < 10000; i++) {

for (let k = 0; k < 100; k++) {

var t3 = new Date().getTime()

console.log(‘two time’, t3 - t2)

两个循环的次数的是一样的,但是 j 与 k 的初始化次数是不一样的

  • 第一个循环的 j 的初始化次数是 100 次,k 的初始化次数是 10w 次

  • 第二个循环的 j 的初始化次数是 1w 次, k 的初始化次数是 1000w 次

所以相同循环次数,外层越大,越影响性能

第六题:统计 1 ~ n 整数中出现 1 的次数

应该是说1-n的时候中间出现1的次数,比如1到11的时候 1、10、11这种 其实就算4次了,因为11中有两个1

function findOne(n){

let count = 0;

for(let i=0;i<=n;i++){

count+=String(i).split(‘’).filter(item=>item===‘1’).length

return count;

第 七 题:Vue 的响应式原理中 Object.defineProperty 有什么缺陷?为什么在 Vue3.0 采用了 Proxy,抛弃了 Object.defineProperty

==============================================================================================

  1. Object.defineProperty无法监控到数组下标的变化,导致通过数组下标添加元素,不能实时响应

  2. Object.defineProperty只能劫持对象的属性,从而需要对每个对象,每个属性进行遍历,如果,属性值是对象,还需要深度遍历。Proxy可以劫持整个对象,并返回一个新的对象。

  3. Proxy不仅可以代理对象,还可以代理数组。还可以代理动态增加的属性。

第 8题:在输入框中如何判断输入的是一个正确的网址。

function isUrl(url) {

try {

new URL(url);

return true;

}catch(err){

return false;

}}

第 9 题:不用加减乘除运算符,求整数的7倍

======================

虽然这样做没什么技术含量,但至少符合题意吧哈哈

function(x){

let arr = Array(x)

let resultArr = […arr,…arr,…arr,…arr,…arr,…arr,…arr]

return resultArr.length

思考

当需要进行避免使用加减乘除的数学运算的时候,通常的方法有:位运算、eval/Function 传参 hack、进制转换配合字符串转换操作等等,我们参考题目来源中提到的几种方式以及其他大佬们提供的解法来看下这道题。

位运算加法 - 连续7次相加

从上面的表可以看出一种实现简单的多位二进制整数加法的算法如下

m 和 n 是两个二进制整数,求 m + n

  1. 用与运算求 m 和 n 共同为 “1” 的位:m’ = m & n

  2. 用异或运算求 m 和 n 其中一个为 “1” 的位:n’ = m ^ n

  3. 如果 m’ 不为 0,那么将 m’ 左移一位(进位,记 m = m’ << 1,记 n = n’,跳回到步骤 1

  4. 如果 m’ 为 0,那么 n’ 就是我们要求的结果。

function bitAdd(m, n){

while(m){

[m, n] = [(m & n) << 1, m ^ n];

return n;

bitAdd(45, 55); //100

既然实现了加法,我们就可以很容易地将“乘7”这个操作通过循环加法实现出来

for(var i = 0; i < 7; i++){

multiply7(7); //49

这里变量 i 自增的时候用了加号,我们用数组将它代替掉

let counter = new Array(7); // 得到 [empty × 7]

while(counter.length){

counter.shift();

大厂面试题

面试题目录

需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端
img

一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导,让我们一起学习成长
m;

[外链图片转存中…(img-axQDws4r-1713057398167)]

[外链图片转存中…(img-B7tJ1RHA-1713057398167)]

[外链图片转存中…(img-soXbrmH5-1713057398167)]

[外链图片转存中…(img-FEvl0XNt-1713057398167)]

    以上就是本篇文章【九道新鲜出炉的大厂面试题,嗯,有点意思(1),2024年最新面试突击 百度网盘】的全部内容了,欢迎阅览 ! 文章地址:http://lianchengexpo.xrbh.cn/news/11082.html 
     资讯      企业新闻      行情      企业黄页      同类资讯      首页      网站地图      返回首页 迅博思语资讯移动站 http://lianchengexpo.xrbh.cn/mobile/ , 查看更多   
最新新闻
二胎概念火了!任泽平:未来四胎五胎可能给奖励
  人口政策问题再次广受关注。  昨日晚间,央行微信公众号发布题为《关于我国人口转型的认识和应对之策》的工作论文,聚焦了
全球下载量突破20亿时TikTok遭遇“围剿”,张一鸣对公司员工说了啥
抖音短视频国际版TikTok近日在美国的遭遇不断反转、不断刷新。虽然特朗普对其封禁令尚未最终拍板,但TikTok在海外年轻人中的火爆
如何查询手机流量?查询手机流量方法教学
  手机是一个我们现在广泛使用的电子产品,我们除了利用手机进行通话之外,最多的就是利用手机上网了。如果想要利用手机上网的
孙楠:希望自己的音乐带给观众快乐
  中新网杭州6月25日电 (胡小丽 刘文彬)1990年,孙楠发行了首张个人专辑《弯弯的月亮》,从此走上职业歌手的道路。到今天,已
【夜读】7条成长建议,送给正在努力的你
01改变自己会痛苦,不改变自己会吃苦不抗拒改变、不用陈旧的方式去处理新问题,是一个人走向成熟的标志。很多时候,只是一个细节
tiktok前身是什么发展历史,一文带你了解tiktok发展历程
在互联网发展如此迅速的今天,各种的媒体社交改变了我们的生活,带来了更多的便利条件,让我们了解这个周围以及世界的最新咨询。
中考倒计时,科学备考秘籍请收好
  本报记者潘洁婷通讯员王晓敏  今年是“双减”政策实施以来的首次中考,距离2022年中考还有不足一个月时间。备考冲刺阶段,
千万粉丝!他突然全网被封
近日,在抖音拥有1800多万粉丝的倪海杉账号被平台封禁。关于倪海杉账号被封原因,网络上有多种猜测。另外,倪海杉在快手上拥有50
全新 Model 3 发布!内外饰全面焕新,屏幕换挡进入全民时代
6年前,特斯拉为 Model 3的亮相开了一场盛大的发布会,特斯拉首席执行官、首席设计官悉数到场。Model 3是公司当前的头等要事。马
一部具有重大警世意义和很高文学价值的力作——评屈全绳的长篇小说《鹅头岭》
作者:汪守德一按一般人的想象,有着数十年从军经历的老将军,离休之后不再为公务缠身,不再因百事纠结,或写一点回忆录之类的轻
本企业新闻
推荐企业新闻

点击拨打: