var a = 0, b = 0; function A(a) {A = function (b)...一道关于作用域的面试题

爱被打了一巴掌 2023-02-28 12:54 62阅读 0赞

var a = 0;

b = 0;

function A(a) {

  1. A = function (b) \{
  2. console.log(a + b++)
  3. \}

console.log(a++)

}

A(1)

A(2)

JavaScript特性:
闭包机制:闭包创建后,可以保存创建时的活动对象。
自加操作符:++,当++作为后缀操作符时,调用++的表达式的值为自加前的自加对象的值。

此处说明 ++操作符的特性。
var i = 0;
var eg = i++
console.log(i, eg) // 1 0

第一次调用A时,执行到console.log(a++)时,a已经完成自加,此时a的值为2,a++的值为1。

A(1)=1

第二次调用A时,A已经被重新赋值,指向了一个新的函数引用;

由于标识符A是在全局作用域定义的,所以在函数内部被重新赋值,在全局作用域也可以访问到重新赋值后的函数。

此时,也创建了一个闭包,该闭包保存了创建环境的活动对象。

此时活动对象:{ a: 2 },同时,根据传入的数值2,确定 b = 2,b++值为3。

执行到 console.log(a + b++),故而输出4

A(2)=4

发表评论

表情:
评论列表 (有 0 条评论,62人围观)

还没有评论,来说两句吧...

相关阅读

    相关 关于a,b = b, a理解

    python有一种unpacking(拆分)写法,这种写法可以让我们只用一条语句,就可以把数据结构里面的多个元素值分别赋给多个相应变量(凡是可迭代的对象都能拆分,无论它里面有多