酷家乐二面题

  1. vue的双向绑定原理
  2. Object.defineProperty的缺点
1.Object.defineProperty无法监控到数组下标的变化,导致通过数组下标添加元素,不能实时响应;
2.Object.defineProperty只能劫持对象的属性,从而需要对每个对象,每个属性进行遍历,如果,属性值是对象,还需要深度遍历。Proxy可以劫持整个对象,并返回一个新的对象。
3. Proxy不仅可以代理对象,还可以代理数组。还可以代理动态增加的属性。

https://github.com/Advanced-Frontend/Daily-Interview-Question/issues/90
3. 讲讲闭包
链接
4. 闭包有哪些危害

  1. 在这里插入图片描述
    f有a和b方法吗 讲一下这个的原型链
    有a方法 没有b方法

  2. 箭头函数和普通函数有哪些不同,this指向,箭头函数有原型对象吗
    58
    在这里插入图片描述

  3. 讲一下作用域和作用域链
    作用域

  4. 讲一下强缓存和协商缓存的状态码,它们的相同点在什么地方。不同点在什么地方
    https://blog.csdn.net/wsymcxy/article/details/82154397

  5. 讲一下原型链和原型对象

  6. 讲一下js的全局作用域
    应该是面试官在提醒我 作用域从全局作用域 函数作用域 块级作用域这三块来说

  7. 讲一下垃圾回收
    红宝书p78

js具有垃圾自动收集机制,也就是执行环境会负责管理代码执行过程中所使用的内存。垃圾收集机制的原理很简单。找出那些不在继续使用的变量,然后释放其占用的内存。

js中最常用的垃圾回收方式就是标记清除。当变量进入环境时,例如,在一个函数中声明一个变量,就将这个变量标记为"进入环境",从逻辑上讲,永远不能释放进入环境变量所占用的内存,因为只要执行流进入相应的环境,就可能会用到它们。而当变量离开环境时,则将其标记为"离开环境"。`


function test(){
    var a = 10;    //被标记"进入环境"
    var b = "hello";    //被标记"进入环境"
}
test();    //执行完毕后之后,a和b又被标记"离开环境",被回收

语言引擎有一张"引用表",保存了内存里面所有资源(通常是各种值)的引用次数。如果一个值的引用次数是0,就表示这个值不再用到了,因此可以将这块内存释放。引用计数的含义是跟踪记录每个值被引用的次数。当声明了一个变量并将一个引用类型值赋给该变量时,则这个值的引用次数就是1,如果同一个值又被赋给另一个变量,则该值的引用次数加1。相反,如果包含对这个值的引用的变量又取得了另外一个值,则这个值的引用次数减1,当这个值的引用次数为0时,则说明没有办法再访问这个值了,因此就可以将其占用的内存空间回收回来。

let aa = []   // 数组[]引用1次
let bb = aa  //  数组引用2次
bb = null  //  释放内存,引用还剩下1次,即变量aa的引用还存在

面试官评价:基础概念不是很清楚 估计又要凉了
加油变强

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值