大家应该写过下面类似的代码吧,其实这里我想要表达的是有时候一个方法定义的地方和使用的地方会相隔十万八千里,那方法执行时,它能访问哪些变量,不能访问哪些变量,这个怎么判断呢?这个就是我们这次需要分析的问题——词法作用域 var classA = function () { this.prop1 = 1; } classA.prototype.func1 = function () { var that = this, var1 = 2; function a() { return function
最近在看阮一峰老师的<ES6> 看到let时,发现一处for循环很神奇的地方. 书中的原话是:“另外,for循环还有一个特别之处,就是设置变量的那部分是一个父作用域,而循环体内部是一个单独的子作用域.” 书中的例子是: for(let i = 0; i < 3; i++){ let i = 'abc'; console.log(i); } //abc //abc //abc 在for循环体内部,用let 声明一个变量i为‘abc’,而for循环设置变量的地方也是let 声明的变量i. l
定义可变参数的函数,需要在stdarg.h头文件中定义的va_list类型和va_start.va_arg.va_end三个宏. 定义可变参数函数 va_list ap; //实际是定义一个指针va_start(ap,num); // 用va_start宏,让ap指向num参数后面的那个参数. int i = va_arg(ap,int); // va_arg(ap,int) 读取ap指向的变量,ap指向下一个参数.读书的数据类型有va_arg的第二个参数控制 int * p_arg = v