js高级程序设计第四章(部分整理)

变量、作用域、内存问题

4.1 基本类型和引用类型的值

  • 基本类型: undefined, null, boolean, number, string(占固定空间,保存在栈内存)
  • 引用类型: 保存在内存中的对象(属性的集合),js不允许直接访问内存位置(即操作对象的内存空间),引用类型按引用访问,操作对象时是在操作对象的引用而非实际的对象。(保存在堆内存)

4.1.2 变量复制

  • 基本类型:一个变量复制另一个变量的值,会创建这个值的副本(二者的改动互不影响)
image.png
  • 引用类型: 变量间的复制,复制的是指针,因此都会指向同一个对象(故改动会相互影响)
image.png

4.1.3 参数传递(都是值传递
基本类型和引用类型的传递其实都和他们的变量复制一样,被传递的参数会复制到函数的局部变量中(函数的命名参数或者arguments对象中的某个元素),引用类型的传递在函数内改变则函数外的引用类型的值也会影响。(只要引用类型的引用都是指向同一个内存地址)
题外话: 引用类型不是引用传递的证明

引用传递: 对函数传递参数时将实际参数的地址传递到函数中(并非复制一个副本后传递而是指向同一个地址),那么在函数内对参数的修改将会影响实际参数。

function setId(obj) {
  obj.id = 1;
  obj = new Object();
  obj.id = 2;
}
var person = new Object();
setId(person);
alert(person.Id); 
//输出1,若是引用传递应该输出2

4.1.4 检测类型

  • typeof: 确定一个变量是 undefined boolean number 还是string的工具,若是对象或null返回object,函数返回function(注意null也返回object, 但null instanceof Object 返回 false)
  • instanceof 判断对象是什么类型对象的实例(根据原型链识别),返回true或者false。
//引用类型都是Object实例返true,但基本类型都是返回false
alert(null instanceof Object);//返回false

4.2 执行环境和作用域

  • 执行环境(简称:环境)定义了变量有权访问的其他数据,决定了他们各自的行为,每个执行环境都有一个与之关联的变量对象,环境中定义的变量和函数都保存于此对象中。
    • 执行环境的类型:全局和局部(函数)
    • 全局执行环境:最外围的一个执行环境 ,js实现所在的宿主环境不同,则执行环境也不同。web浏览器中,全局环境为window对象。
    • 销毁:某执行环境中的所有代码执行完毕,该环境也会销毁,故保存在其中的变量和函数定义也销毁。全局执行环境正则应用程序退出才销毁(如浏览器或网页关闭)。
  • 作用域(传送门:):当代码在一个环境中执行时,会创建变量对象的一个作用域链,作用:保证对执行环境有权访问的所有变量和函数的线性、有序访问。
    • 作用域链的前端始终是当前执行代码所在环境的变量对象
    • 标识符(变量)的解析是沿着作用域链一级级地向上搜索的过程,从作用域链前端到找到为止。
    • 全局执行环境对象是作用域链中最后一个对象。

4.2.1 延长作用域链:作用域前端增加一个对象,如:

  • try-catch中的catch块(对于catch语句,会新建一个变量对象,其中包含的是被抛出的错误生命)
  • with语句

4.2.2 没有块级作用域(通过let定义变量可以实现块级作用域)

在其他语言中,花括号封闭的代码块会有自己的作用域(在js中指自己的执行环境)

如js中if和for的代码块是没有独立的执行环境,变量会添加到外部的执行环境中

4.3 垃圾收集:js有自动的垃圾收集机制(周期性运行),可以通过设置变量为null来进行垃圾收集

4.3.1 标记清除(js最常用的垃圾收集方式):不使用的值加上标记后清除

  • js给内存中的所有变量都加上标记,然后去掉环境中的变量以及被环境中变量引用的变量的标记,在此之后在被加上标记的变量将准备删除,因为它们已经无法被访问,最后由垃圾收集器完成内存清除带标记的值。(大部分浏览器都支持,不同浏览器垃圾收集的时间间隔不同)
    4.3.2 引用计数(不常见的垃圾收集方式)
  • 引用计数:跟踪记录每个值被引用的次数,引用次数为0时就无法访问这个值,可以将内存空间回收。(循环引用时会有问题)

4.3.4内存管理

  • 为了有效回收内存,应该即时解除不再使用的全局对象、全局对象属性以及循环引用变量的引用(通过设置为null),
  • 局部变量会在离开执行环境时被解除引用(只要在外部没有被引用)。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 230,501评论 6 544
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 99,673评论 3 429
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 178,610评论 0 383
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 63,939评论 1 318
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 72,668评论 6 412
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 56,004评论 1 329
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 44,001评论 3 449
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 43,173评论 0 290
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 49,705评论 1 336
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 41,426评论 3 359
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 43,656评论 1 374
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 39,139评论 5 364
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 44,833评论 3 350
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 35,247评论 0 28
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 36,580评论 1 295
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 52,371评论 3 400
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 48,621评论 2 380

推荐阅读更多精彩内容