首页 > 其他分享 >一天10个js面试题(七)

一天10个js面试题(七)

时间:2024-10-21 09:18:13浏览次数:3  
标签:10 面试题 ACK SYN js promise 内存 服务端 客户端

1、promise的链式调用?

  • 链式调用的话就是说 then 的函数和新 promise 的 resolve 一起 push 到前一个 promise 的 callbacks 数组中
  • 当前一个 promise 完成后,调用它的 resolve 变更状态,在这个 resolve 里会依次调用 callbacks 里的回调,这样就执行了 then 里的方法了
  • 然后等 then 里的方法执行完成后,返回一个结果
  • 如果这个结果是个简单的值,就直接调用新 promise 的 resolve,让其状态变更,这又会依次调用新 promise 的 callbacks 数组里的方法,循环往复
  • 如果返回的结果是个 promise,则需要等它完成之后再触发新 promise 的 resolve,所以可以在其结果的 then 里调用新 promise 的 resolve,基本就是这么一个过程吧。

2、三次握手?

  • 第一次握手(SYN)客户端发送SYN包:
  • 客户端发送一个 SYN 包到服务端。这个 SYN 包的 Seq=0,表明客户端希望与服务端建立连接,并且告知服务端的起始序列号为0。
  • 第二次握手(SYN-ACK)服务器回应SYN-ACK包:
  • 服务器确认客户端的SYN请求,发送SYN和ACK,Ack=1, 说明服务器已经收到客户端 Seq=0 的字节,期望下次收到服务端 Seq=1 的字节,Seq = 0,告知客户端的起始序列号也为0。
  • 第三次握手(ACK)客户端发送ACK包:
  • 客户端收到服务器的SYN-ACK包后,会发送一个ACK包。这个包的ACK=1,说明客户端已经收到服务端 Seq=0 的包,期望收到 Seq=1 的包

3、四次挥手过程?

  • 第一次挥手:客户端发送一个FIN,用来关闭客户端到服务器的数据传送,客户端进入fin_wait_1状态。
  • 第二次挥手:服务端收到FIN后,发送一个ACK给客户端,确认序号为收到序号+1,服务端进入Close_wait状态。
  • 第三次挥手:服务端发送一个FIN,用来关闭服务端到客户端的数据传送,服务端进入Last_ack状态。
  • 第四次挥手:客户端收到FIN后,客户端进入Time_wait状态,接着发送一个ACK给服务端,确认后,服务端进入Closed状态,完成四次挥手。

4、事件循环?

  • JS 是一种单线程编程语言,这就是说它在同一时间只能执行一个任务,或者说,在任何给定的时间里,JS 引擎中只会有一个执行线程来处理JS脚本。这个执行线程遵循从上至下逐行执行代码的原则。
  • 事件循环呢,就是JS执行上下文中的一种机制,用来处理异步操作。它的核心思想是把所有的异步任务放入一个队列中,然后按照队列中的顺序依次执行,直到队列为空为止。主线程从"任务队列"中读取事件,这个过程是循环不断的,所以整个的这种运行机制又称为Event Loop(事件循环)。
  • 下面是执行顺序:
  • 1.先执行同步代码,所有同步代码都在主线程上执行,形成一个执行栈。
  • 2.当遇到异步任务时,会把它挂起并添加到任务队列中,宏任务放入宏任务队列,微任务放进微任务队列。
  • 3.当执行栈为空时,事件循环从任务队列中取出一个任务,加入到执行栈中执行。
  • 4.重复上述步骤,直到任务队列为空。
  • 概括以下就是 js是一门单线程语言,通过事件循环机制实现异步执行代码。

5、单线程的好处?

  • 首先就是占用资源少,因为只有一个线程
  • 然后相比于多线程的话,它不用切换执行上下文,速度更快;
  • 然后对于访问DOM结构获取变量的时候不用考虑复杂的并发

6、JSON.stringify实现深拷贝的缺点?

  • 会忽略 undefined和Symbol
  • 不能序列化函数
  • 无法处理循环引用
  • 不支持RegExp(正则)和Map还有Set

7、js数组去重方法?

  • 利用 ES6 Set 去重(ES6 中最常用)
  • 利用 for 嵌套 for,然后 splice 去重(ES5 中最常用)
  • 利用 indexOf 去重
  • 利用 sort()
  • 利用 includes()
  • 利用 hasOwnProperty
  • 利用 filter
  • 利用递归去重
  • 利用 Map 数据结构去重

8、BigInt 的使用?

  • BigInt 是一种数值数据类型,用于表示旧数值数据类型 number 无法表示的小数和大数。每个 BigInt 值都必须在数字后包含小写字母 n。
  • 使用场景:
  • 财务计算:BigInt 在财务计算中很重要,因为可以处理非常大量的交易和货币转换
  • 密码学和安全计算:BigInt 在密码学中用于生成非常难以预测或破解的非常大的随机数
  • 游戏开发:在游戏开发中,大数通常用于保存时间戳、分数和跟踪进度。 BigInt 的使用确保了此类值的准确表示
  • 分布式系统:分布式系统需要唯一身份才能准确执行。由于 BigInt 值是无限的,因此它们可用于生成标识符和密钥

9、基本数据类型和引用数据类型的区别?

  • 基本数据类型存储在栈内存中
  • 数据存储时,基本数据类型在变量中存的是值,引用数据类型在变量中存储的是空间地址

10、什么是堆栈内存?

  • 1.堆内存和栈内存是浏览器形成的两个虚拟内存
  • 2.栈内存主要是用来存储基本数据的值,栈内存是一种简单的存储,但是存储的数据都是有范围上线的,一旦超过,就会造成栈溢出
  • 3.堆内存主要是用来存储引用数据类型的
  • 堆内存:存储引用类型,对象类型就是键值对,函数就是代码字符串
  • 堆内存释放:将引用类型的空间地址变量赋值成null,或者没有变量占用堆内存了,浏览器就会释放掉这个地址
  • 栈内存:提供代码执行的环境和存储基本类型值
  • 栈内存释放:一般当函数执行完后,函数的私有作用域就会被释放掉

    

标签:10,面试题,ACK,SYN,js,promise,内存,服务端,客户端
From: https://blog.csdn.net/m0_62474008/article/details/143103737

相关文章

  • JS中数组的splice()方法介绍 及 用原生JS手写数组splice()方法
    一、splice是什么splice()方法是用来对数组进行增、删操作,该方法返回被删除的元素,改变原数组二、splice()方法接受三个及以上的参数:第一个参数:第一个参数是起始位置(数组的索引)第二个参数:第二个参数是要删除的元素个数,如果该参数是负数则默认为0第三个参数及往后参数:这些......
  • C10-08-宽字节注入-mysql注入之getshell-sqlmap
    一宽字节注入利用宽字节注入实现“库名-表名”的注入过程。靶场环境:容器镜像:area39/pikachu宽字节概念1、如果一个字符的大小是一个字节的,称为窄字节;2、如果一个字符的大小是两个及以上字节的,称为宽字节;像GB2312、GBK、GB18030、BIG5、Shift_JIS等编码都是常见的宽字节......
  • 10.14-10.20 总结
    联考题解:https://www.cnblogs.com/british-union/p/liankao.html如果忽略挂分,这周打的还可以。但是问题是挂了不少分导致实际得分远不如期望得分。做题:做了几道ProjectEuler,有一道没想出来:588,638,457,307。P10353:群论题AGC012F尝试枚举一下前几个的限制,发现限制就是在\([i,......
  • 基于YOLOv10的农场实时目标检测系统(python+pyside6界面+系统源码+可训练的数据集+也完
    摘要:        基于YOLOv10的农场实时目标检测系统,利用4393张图片(3905张训练集,488张验证集)进行模型训练,最终开发出一个高效的农场目标检测模型。为了方便用户操作和实时检测,本系统还开发了基于Python和PySide6的图形用户界面(GUI),实现了农场目标的实时检测功能。此外,为保......
  • P1074
    暴搜+剪枝。#include<bits/stdc++.h>usingnamespacestd;structf{intrank,sum;}cou[10];inta[10][10],hang[10][10],lie[10][10],gong[10][10],s[100][4],u,ok,most=-1,have;intwhich(inti,intj){if(i<=3){if(j<=3)return1;......
  • C#/.NET/.NET Core技术前沿周刊 | 第 10 期(2024年10.14-10.20)
    前言C#/.NET/.NETCore技术前沿周刊,你的每周技术指南针!记录、追踪C#/.NET/.NETCore领域、生态的每周最新、最实用、最有价值的技术文章、社区动态、优质项目和学习资源等。让你时刻站在技术前沿,助力技术成长与视野拓宽。欢迎投稿、推荐或自荐优质文章、项目、学习资源等。每......
  • P1078
    然而题单里就是有这题……dij,照亮世界!#include<bits/stdc++.h>usingnamespacestd;intn,k,m,s,t,a[105][105],wen[105];intd[100005];boolvis[100005];intqi,mo,f;inlineintread(){intx=0;charch=getchar();while(ch>='0'&&ch<='9......
  • ChatGPT国内中文版镜像网站整理合集(2024/10/21)
    ​一、GPT中文镜像站① yixiaai.com 支持4o以及o1,支持MJ绘画② chat.lify.vip 支持通用全模型,支持文件读取、插件、绘画、AIPPT③ AIChat 支持GPT3.5/4,4o以及MJ绘画1.什么是镜像站镜像站(MirrorSite)是指通过复制原始网站内容和结构,创建的备用网站。其主要目的是在原......
  • 大道至简前10至20章读后感
    在深入阅读了《大道至简软件工程实践者的思想》的前10章至20章后,我对软件工程的理解又上升到了一个新的高度。这部分内容进一步深化了“大道至简”的理念,让我更加坚信在软件工程的实践中,简洁高效才是关键。作者通过具体的案例和分析,展示了如何在复杂的项目中运用简单的方法......
  • 关于Window10激活相关(自用,过期了再来看看)
    第一步:关闭所有防毒软件,还有Windows防火墙,非常重要,具体的就是:电脑设置-windows安全中心-病毒威胁巴拉巴拉。关闭实时保护,另外下拉打开排除项-添加巴拉巴拉:添加文件就是可以选压缩包等等,添加文件夹就是文件夹那些,会看不见压缩包,各取所需。不然就会出现类似不准打开或者解......