前端面试(JS部分持续更新中)

542 阅读2分钟
  1. 闭包
  • 什么是闭包?
    • 密闭的容器,类似于set,map容器,存储数据的
    • 闭包是一个对象,存储是键值对的形式
  • 闭包的产生
我将会从js的垃圾回收,作用域链,代码执行环境讲起

首先,产生闭包的条件是,函数嵌套,内部函数引用了外部函数的局部变量,这样导致了这个变量在内存上无法被回收,由此产生了所谓的闭包

那么这个变量为什么无法被回收了呢,这就要从js的垃圾回收谈起,js代码在执行时,会进入执行环境
而垃圾回收会根据代码是处于进入环境还是退出环境状态,对于处于进入环境状态的代码,系统认为它可能马上被使用,是绝对不会去回收它的,所以它会一直在内存上,也就说,闭包是因为代码处于执行环境,所以不会被回收

可是为什么代码会在执行环境呢,外部函数代码明明已经结束了,它的变量应该被释放呀
这就跟作用域链有关了,内部函数使用变量时,先在当前环境查找,没有的话,会从包含环境内找,此时,它在外部的包含环境中找到了,所以它就拿过来用,我们之前说的当代码进入执行环境时,是不会被回收的,而外部函数的变量,此时正在被使用(作用域链的原理),所以这个变量仍然处于执行环境,所以它是不会被回收的,也就保存在了内存上。

以上就是闭包产生的原因了
也因此,闭包是一把双刃剑,它延长了变量的生命周期,但是它也会造成内存泄漏,因为一直不回收
  1. 原型/原型链
  • 原型是一个对象,所以也称原型对象prototype
    • 解决函数内存浪费的问题
    • 共享方法
  • 对象原型 __proto__
    • 每个对象身上,系统会自动为其添加一个__proto__,它指向构造函数的原型对象prototype,所以对象可以访问原型对象上的方法
    • obj.proto === Object.prototype 返回true
  • constructor 构造函数
    • prototype和__proto__都有一个constructor属性,它指回这个对象的构造函数
obj.prototype = {
 constructor: 构造函数,
 func(){}
}
  • 原型对象、对象原型、构造函数、实例对象之间的联系,它们构成了原型链
  • JS的查找规则
    • 按照原型链的机制查找
    • 冲突时采取就近原则
  • 原型对象的this指向
    • 构造函数的this指向实例化对象
    • 原型对象的this指向调用该原型对象方法的实例对象
    • 总结来说就是谁调用指向谁