今天在看PPTV几道题目,顺便联系起红宝书《JavaScript高级程序设计》一起看了起来。

1.

var msg = 'hello';//顶级作用域windwo下有个变量msg
function great(name, attr) {
var name = 'david';
var greating = msg + name + '!';
var msg = '你好';
for (var i = 0; i < 10; i++) {
var next = msg + '你的id是' + i * 2 + i;
}
alert(arguments[0]);
alert(arguments[1]);
alert(greating);
alert(next);
}
great('Tom')

解析:

函数great有2个实参,一个是name,一个是atr,顶级作用域window下有个变量msg,而函数great内部也有变量msg,函数great运行的时候传入的参数是tom,而且是一个参数,即是实参name的传参,alert(arguments[0]);arguments即是函数实参的类数组,所以arguments[0]自然是name,而因为函数有个参数name,又因为,所以alert(arguments[0])即是david。
alert(arguments[1]);因为没有第二个参数所有是undefined
。alert(greating),关于这个的结果,就要考虑到了预编译及其变量查找,因为函数内部已经有了msg又因为变量查找的时候先在自己的作用域内部查找如果没有找到再从外面作用域一层一层向外查找,这里函数内部已经有定义变量var msg='你好',所以已经在自己的作用域下找到msg,又因为变量运行的时候要对var定义的变量进行预编译并且把变量赋值成undefined,所以函数运行的时候msg只是undefined,当运行到了var msg='你好';之后msg才是你好,而name是david所以结果是undefineddavid!
字符串连接,接着alert(next);因为,这里是个循环,每次都进行了一个创建和摧毁的机制,循环完成的时候i应该是等于9,即var next=msg+'的你的id是'+i*2+i ;等于var next=你好+'你的id是'+i*9+9 ;这里也是字符串连接,所以是你好你的id是189。
 

P64----理解参数

ECMAscript中的参数在内部是通过一个数组来表示的,在函数体内可以通过arguments对象来访问这个数组,从而获取传递给函数的每一个参数。这里arguments[0]就是name,而arguments[1]没有定义,所以为undefined。

P73---执行环境及作用域:

全局变量和函数都是作为windows对象的属性和方法创建的,某个执行环境中的所有代码执行完毕后,该环境被销毁,保存在其中的所有变量和函数定义也会随之销毁。每个函数都有自己的执行环境,当执行流进入一个函数时,函数的环境会被推入一个环境栈中,而在函数执行完后,栈将被环境弹出,把控制权返回给之前的执行环境。当代码在一个环境中执行时,会创建变量对象的一个作用域链,来保证对执行环境有权访问的所有变量和函数的有序访问。作用域的前端,始终都是当前执行的代码所在环境的变量对象。标识符解析是沿着作用域链一级一级地搜索标识符的过程。搜索过程始终从作用域链的前端开始,然后逐级向后回溯,直至找到标识符为止。

2.  

var t=true;
window.setTimeout(function(){
t=false;
},1000);
while(t){ }
alert('end');

考察线程。JS只有一个代码线程,setTimeout是异步,。所以一但这个线程不结束,所有的其它线程(比如计时器setTimeout)都不能执行。JavaScript引擎是单线程运行的,浏览器无论在什么时候都只且只有一个线程在运行JavaScript程序.

setTimeout是异步线程,需要等待js引擎处理完同步代码(while语句)之后才会执行,while语句直接是个死循环,js引擎没有空闲,不会执行下面的alert,也不会插入setTimeout。所以即使这个时候你把setTimeout的时间改成0,他还是不会执行。会先执行while(t){}再alert,但这个循环体是死循环,所以永远不会执行alert。
至于说为什么不执行setTimeout,是因为js的工作机制是:当线程中没有执行任何同步代码的前提下才会执行异步代码,setTimeout是异步代码,所以setTimeout只能等js空闲才会执行,但死循环是永远不会空闲的,所以setTimeout也永远不会执行。

3.

Object.prototype.xiaomo=function(){
return this;
}
var obj1={};
var obj2=Object.create(Object.prototype);//这个就相当于new Object或者{}
var obj3=Object.create(null);//这个是得到一个原型链干净的对象 function notice(a,b){
if(a.xiaomo){
console.log('obj'+b+'有原型xiaomo的方法')
}else{
console.log('obj'+b+'没有原型xiaomo的方法')
}
}
Object.create(null) instanceof Object === false;
notice(obj1,1);
notice(obj2,2);
notice(obj3,3);

 答案是:

 
obj1有原型xiaomo的方法
 
obj2有原型xiaomo的方法
 
obj3没有原型xiaomo的方法

2014PPTV-题解的更多相关文章

  1. 2016 华南师大ACM校赛 SCNUCPC 非官方题解

    我要举报本次校赛出题人的消极出题!!! 官方题解请戳:http://3.scnuacm2015.sinaapp.com/?p=89(其实就是一堆代码没有题解) A. 树链剖分数据结构板题 题目大意:我 ...

  2. noip2016十连测题解

    以下代码为了阅读方便,省去以下头文件: #include <iostream> #include <stdio.h> #include <math.h> #incl ...

  3. BZOJ-2561-最小生成树 题解(最小割)

    2561: 最小生成树(题解) Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1628  Solved: 786 传送门:http://www.lyd ...

  4. Codeforces Round #353 (Div. 2) ABCDE 题解 python

    Problems     # Name     A Infinite Sequence standard input/output 1 s, 256 MB    x3509 B Restoring P ...

  5. 哈尔滨理工大学ACM全国邀请赛(网络同步赛)题解

    题目链接 提交连接:http://acm-software.hrbust.edu.cn/problemset.php?page=5 1470-1482 只做出来四道比较水的题目,还需要加强中等题的训练 ...

  6. 2016ACM青岛区域赛题解

    A.Relic Discovery_hdu5982 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Jav ...

  7. poj1399 hoj1037 Direct Visibility 题解 (宽搜)

    http://poj.org/problem?id=1399 http://acm.hit.edu.cn/hoj/problem/view?id=1037 题意: 在一个最多200*200的minec ...

  8. 网络流n题 题解

    学会了网络流,就经常闲的没事儿刷网络流--于是乎来一发题解. 1. COGS2093 花园的守护之神 题意:给定一个带权无向图,问至少删除多少条边才能使得s-t最短路的长度变长. 用Dijkstra或 ...

  9. CF100965C题解..

    求方程 \[ \begin{array}\\ \sum_{i=1}^n x_i & \equiv & a_1 \pmod{p} \\ \sum_{i=1}^n x_i^2 & ...

  10. JSOI2016R3 瞎BB题解

    题意请看absi大爷的blog http://absi2011.is-programmer.com/posts/200920.html http://absi2011.is-programmer.co ...

随机推荐

  1. FMX下Edit只能输入数字

    procedure TForm1.Edit1KeyDown(Sender: TObject; var Key: Word; var KeyChar: Char; Shift: TShiftState) ...

  2. 平滑处理Smooth之图像预处理算法-OpenCV应用学习笔记三

    大清早的我们就来做一个简单有趣的图像处理算法实现,作为对图像处理算法学习的开端吧.之所以有趣就在于笔者把算法处理的各个方式的处理效果拿出来做了对比,给你看到原图和各种处理后的图像你是否能够知道那幅图对 ...

  3. 快速学习C语言四: 造轮子,ArrayList

    高级语言里的列表是最常用的数据结构,在C里造个轮子玩玩,C没有泛型,先用int练习. Collection的ADT一般有hasnext,next,add, remove操作,List一般还加了remo ...

  4. 大数据存储:MongoDB实战指南——常见问题解答

    锁粒度与并发性能怎么样? 数据库的读写并发性能与锁的粒度息息相关,不管是读操作还是写操作开始运行时,都会请求相应的锁资源,如果请求不到,操作就会被阻塞.读操作请求的是读锁,能够与其它读操作共享,但是当 ...

  5. Grpc微服务从零入门

    快速入门 安装 JDK 毫无疑问,要想玩Java,就必须得先装Java JDK,目前公司主要使用的是Oracle JDK 8,安装完成后要配置环境才能正常使用,真蠢,不过也就那么一下下,认了吧.配置方 ...

  6. 升级AutoMapper后遇到的“Missing map”与“Missing type map configuration”问题

    前几天发现 AutoMapper 3.3 的一个性能问题(详见:遭遇AutoMapper性能问题:映射200条数据比100条慢了近千倍),于是将 AutoMapper 升级至最新的 5.1.1 看是否 ...

  7. 扒皮下GitHub 404的图片层次轴动特效

    今天要克隆的前端特效非常有意思,可以参见GitHub404页面 https://github.com/vajoy/master/index.html 记得之前华为在站酷发布EMUI设计大赛的主页也用了 ...

  8. 【面试必备】CSS盒模型的点点滴滴

    从接触CSS布局开始,就一直在听盒模型的概念了,网上的文章有很多,深浅不一.有些人会认为盒模型很简单,不就是border.margin.padding.content嘛,一个元素所占的空间就是把它们都 ...

  9. 常用CSS优化总结——网络性能与语法性能建议

    在前端面试中最常见的问题就是页面优化和缓存(貌似也是页面优化),被问了几次后心虚的不行,平然平时多少会用到一些,但突然问我,很难把自己知道的都说出来.页面优化明显不是一两句能够说完的,这两天总结了一下 ...

  10. 三天学会HTML5 之第一天

    引言 HTML5 一直是非常热门的话题,因此此系列文章主要从一些基本功能开始讲起,逐步深入了解HTML5的新概念. 首先了解一些基本的术语和概念. SGML, HTML,XML三者之间的区别 Doc类 ...