高级JS测试题求大佬解决

JavaScript018

高级JS测试题求大佬解决,第1张

let A = [6,9,10,11,13,15]

let B = [2,3,4,5,6,9,10]

let C = [2,3,4,7,9,10]

let D = []

let k = 0

let interval = setInterval(function () {

let num = A[k]

if(B[0]<= A[k]){

if(C[0]<=B[0]){

num = C[0]

C.splice(0,1)

}else{

num = B[0]

B.splice(0,1)

}

}else{

if(C[0]<=A[k]){

num=C[0]

C.splice(0,1)

}else{

num = A[k]

k++

}

}

if(k == A.length + 1){

clearInterval(interval)

console.log('D:' + D)

return

}

D.push(num)

},10)

js运行前有一个类似编译的过程即词法分析,词法分析主要有三个步骤:

函数在运行的瞬间,生成一个活动对象(Active Object),简称AO

1.分析参数

2.分析变量声明:如var age或var age=23

3.分析函数的声明,如果有function name(){}把函数赋给AO.name ,覆盖上一步分析的值

例子1:

词法分析阶段:

例子2:

词法分析阶段:

a和b在词法分析时,区别:

词法作用域

所谓词法作用域是说,其作用域为在定义时(词法分析时)就确定下来的,而并非在执行时确定。白话就是在函数未执行前,函数执行的顺序已经被确定,而不是类似JAVA一样,是在执行前根本不知道执行顺序。

你说js函数的传参是按值传递,应该是看到《js高级》里面作者这么说的吧,其实有不少人对作者的观点提出了质疑,有的人觉得如果参数是引用类型,那么就是按引用传递的,还有一种说法叫“按共享传递”。

我个人偏向于的观点是:如果参数是js基本数据类型,那么就是按值传递;如果是引用类型如对象、数组、函数,那么就是按引用传递。用这个观点去解释你的例子,应该是没有矛盾的地方的。①处按照js对象的比较运算规则,只有全等号(据说比较对象时,“===”和“==”是没有区别的)两侧的变量指向的是同一个对象的引用,才返回true,即按引用传递。在“peo = {...}”这一行,实际上是创建了一个函数内的局部对象,开辟了新的内存地址,并将peo变量指向该处,而之前的person变量指向的对象不变,故而②比较的是两个指向不同对象的变量,返回false。

你可以这么去理解js函数传参的过程:js解析器在分析js的函数声明代码时,如果函数有带参数,实际上是在开始时加了一行代码:var 参数1,参数2...;即将参数隐性的声明为函数的局部变量,没有赋值(下面的函数例子可以说明这点,第一个函数虽然声明是有形参,但是调用执行时没有传参,即a只声明未赋值,所以是undefined;第二个函数的a不存在,所以报错)。等到函数真正被调用,传进来实参的时候,只是将实参变量赋给了形参变量,比如你的例子中,函数调用执行时会自动加一句:peo = person即两个不同的变量指向了同一个对象,这自然就是按引用传递。

function aa(a) {

    console.log(a)

}

aa() //输出undefined

function ab() {

    console.log(a)

}

ab() //报错,Uncaught ReferenceError: a is not defined