iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > VUE >如何理解JavaScript变量、作用域及内存
  • 685
分享到

如何理解JavaScript变量、作用域及内存

2024-04-02 19:04:59 685人浏览 独家记忆
摘要

这期内容当中小编将会给大家带来有关如何理解javascript变量、作用域及内存,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。基本类型值有:undefined,NUll,

这期内容当中小编将会给大家带来有关如何理解javascript变量、作用域及内存,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

基本类型值有:undefined,NUll,Boolean,Number和String,这些类型分别在内存中占有固定的大小空间,他们的值保存在栈空间,我们通过按值来访问的。

(1)值类型:数值、布尔值、null、undefined。
(2)引用类型:对象、数组、函数。

如果赋值的是引用类型的值,则必须在堆内存中为这个值分配空间。由于这种值的大小不固定(对象有很多属性和方法),因此不能把他们保存到栈内存中。但内存地址大小是固定的,因此可以将内存地址保存在栈内存中。

<script type="text/javascript”> var box = new Object();  //创建一个引用类型 var box = "trigkit4";   //基本类型值是字符串 box.age = 21;    //基本类型值添加属性很怪异,因为只有对象才可以添加属性。 alert(box.age);  //不是引用类型,无法输出; </script>

简而言之,堆内存存放引用值,栈内存存放固定类型值。“引用”是一个指向对象实际位置的指针。

在这里需注意的是,引用指向的是具体的对象,而不是另一个引用。

如何理解JavaScript变量、作用域及内存

这里的对象可以是字符串对象,数字对象,数组对象等

<script type="text/javascript">     var man = new Object();//man指向了栈内存的空间地址     man.name = "Jack";     var man2 = man;//man2获得了man的指向地址      alert(man2.name);//两个都弹出Jack     alert(man.name); </script>

复制变量值

再看下面这个例子:

<script type="text/javascript">     var man = new Object();//man指向了栈内存的空间地址     man.name = "Jack";     var man2 = man;//man2获得了man的指向地址      man2.name = "ming";//因为他们都指向同一个object,同一个name,不管修改谁,大家都修改了     alert(man2.name);//两个都弹出ming     alert(man.name); </script>

由以上可以得出:在变量复制方面,基本类型和引用类型也有所不同,基本类型复制的是值本身,而引用类型复制的是地址。

传递参数

ECMAScript中,所有函数的参数都是按值传递的,

<script type="text/javascript">      function box(num){      //按值传递          num+=10;          return num;      }       var num = 10;      var result = box(num);      alert(result);  //如果是按引用传递,那么函数里的num会成为类似全局变量,把外面的number替换掉      alert(num);    //也就是说,***应该输出20(这里输出10) </script>

js没有按引用传递的,如果存在引用传递的话,那么函数内的变量将是全局变量,在外部也可以访问。但这明显是不可能的。

执行环境及作用域

执行环境是javascript中最为重要的概念之一,执行环境定义了变量或函数有权访问其他数据。

全局执行环境是最外围的执行环境,在WEB浏览器中,全局执行环境是window对象,因此,所有的全局变量的函数都是作为window的属性和方法创建的。

<script type="text/javascript">       var name = "Jack";           //定义全局变量       function setName(){           return "trigkit4";       }        alert(window.name);        //全局变量,最外围,属于window属性       alert(window.setName());  //全局函数,最外围,属于window方法 </script>

当执行环境内的代码执行完毕后,该环境被销毁,保存其中的变量和函数也随之销毁,如果是全局环境,需所有程序执行完毕或网页完毕后才会销毁。

去掉var的局部变量

<script type="text/javascript">       var name = "Jack";       function setName(){           name = "trigkit4";   //去掉var变成了全局变量       }        setName();       alert(name);//弹出trigkit4 </script>

通过传参,也是局部变量

<script type="text/javascript">       var name = "Jack";       function setName(name){    //通过传参,也是局部变量           alert(name);       }        setName("trigkit4");//弹出trigkit4       alert(name);//弹出Jack </script>

函数体内还包含函数,只有这个函数才可以访问内一层的函数

<script type="text/javascript">      var name = "Jack";       function setName(){           function setYear(){    //setYear()方法的作用域在setName()内               return 21;           }       }       alert(setYear());//无法访问,出错  </script>

可以通过如下方法进行访问:

<script type="text/javascript">      var name = "Jack";       function setName(){           function setYear(){    //setYear()方法的作用域在setName()内               return 21;           }           return setYear();       }       alert(setName()); //弹出21 </script>

再一个作用域例子:

<script type="text/javascript">      var name = "Jack";       function setName(){           function setYear(){    //setYear()方法的作用域在setName()内               var b = "hi";     //变量b的作用域在setYear()内               return 21;           }           alert(b);//无法访问        } </script>

当代码在一个环境中执行的时候,就会形成一种叫做作用域链的东西,它的用途是保证对执行环境中有访问权限的变量和函数进行有序访问(指按照规则层次来访问),作用域链的前端,就是执行环境的变量对象。

作用域

变量没有在函数内声明或者声明的时候没有带var就是全局变量,拥有全局作用域,window对象的所有属性拥有全局作用域;在代码任何地方都可以访问,函数内部声明并且以var修饰的变量就是局部变量,只能在函数体内使用,函数的参数虽然没有使用var但仍然是局部变量。

没有块级作用域

// if语句:  <script type="text/javascript"> if(true){                        //if语句的花括号没有作用域的功能。  var box = "trigkit4"; } alert(box);//弹出 trigkit4 </script>

for循环语句也是如此。

变量的查询

在变量的查询中,访问局部变量要比全局变量来得快,因此不需要向上搜索作用域链。

如下例子:

<script type="text/javascript">      var name = "Jack";       function setName(){            var name = "trigkit4";            return name;  //从底层向上搜索变量     }     alert(setName());       </script>

每个环境都可以向上搜索作用域链,以查询变量和函数名;但任何环境都不能通过向下搜索作用域链而进入另一个执行环境。在这里,如果去掉var name = "trigkit4",那么将弹出“Jack”

内存问题

javascript具有自动垃圾回收机制,一旦数据不再使用,可以将其设为”null”来释放引用

循环引用

一个很简单的例子:一个DOM对象被一个Javascript对象引用,与此同时又引用同一个或其它的Javascript对象,这个DOM对象可能会引发内存泄露。这个DOM对象的引用将不会在脚本停止的时候被垃圾回收器回收。要想破坏循环引用,引用DOM元素的对象或DOM对象的引用需要被赋值为null

闭包

在闭包中引入闭包外部的变量时,当闭包结束时此对象无法被垃圾回收(GC)。

var a = function() {
  var largeStr = new Array(1000000).join('x');
  return function() {
    return largeStr;
  }
}();

DOM泄露

当原有的COM被移除时,子结点引用没有被移除则无法回收。

var select = document.querySelector;
var treeRef = select('#tree');

//在COM树中leafRef是treeFre的一个子结点
var leafRef = select('#leaf');
var body = select('body');

body.removeChild(treeRef);

//#tree不能被回收入,因为treeRef还在
//解决方法:
treeRef = null;

//tree还不能被回收,因为叶子结果leafRef还在
leafRef = null;

//现在#tree可以被释放了。

Timers计(定)时器泄露

定时器也是常见产生内存泄露的地方:

for (var i = 0; i < 90000; i++) {   var buggyObject = {     callAgain: function() {       var ref = this;       var val = setTimeout(function() {         ref.callAgain();       }, 90000);     }   }    buggyObject.callAgain();   //虽然你想回收但是timer还在   buggyObject = null; }

调试内存

Chrome自带的内存调试工具可以很方便地查看内存使用情况和内存泄露,在 Timeline -> Memory 点击record即可。

上述就是小编为大家分享的如何理解JavaScript变量、作用域及内存了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网VUE频道。

--结束END--

本文标题: 如何理解JavaScript变量、作用域及内存

本文链接: https://www.lsjlt.com/news/86110.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 如何理解JavaScript变量、作用域及内存
    这期内容当中小编将会给大家带来有关如何理解JavaScript变量、作用域及内存,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。基本类型值有:undefined,NUll,...
    99+
    2024-04-02
  • JavaScript中变量作用域及内存问题的示例分析
    这篇文章给大家分享的是有关JavaScript中变量作用域及内存问题的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。学习要点:1.变量及作用域2.内存问题JavaScri...
    99+
    2024-04-02
  • javascript中变量、作用域和内存的示例分析
    这篇文章主要介绍javascript中变量、作用域和内存的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!javascript 的变量、作用域和内存问题(一)JavaScrip...
    99+
    2024-04-02
  • JavaScript函数执行、作用域链以及内存管理详解
    目录前言函数执行全局执行上下文函数执行上下文作用域链内存管理引用计数标记清除前言 在我们平常编写JavaScript代码的时候,难免会用到函数,函数里面会有各种变量,这些变量的作用的...
    99+
    2023-01-08
    JS函数执行 js作用域链 js内存管理
  • 怎样理解JavaScript中的变量与作用域
    怎样理解JavaScript中的变量与作用域,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1、原始值与引用值6种简单数据类型的值都是原始值, 原始值通过变量赋值给另一个变量时,...
    99+
    2023-06-25
  • JavaScript中变量的作用域详解
    一、变量的分类 在JavaScript中变量分为两种: 全局变量局部变量 二、变量的作用域 1、局部变量的作用域 局部变量:在函数内部定义的变量称为局部变量,其作用域为该函数内部,在...
    99+
    2024-04-02
  • JavaScript变量类型以及变量作用域的示例分析
    这篇文章主要介绍JavaScript变量类型以及变量作用域的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!变量类型ECMAScript变量可能包含两种不同类型的数据值:基本类...
    99+
    2024-04-02
  • 怎么理解并掌握JavaScript中变量和作用域
    这篇文章主要讲解了“怎么理解并掌握JavaScript中变量和作用域”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么理解并掌握JavaScript中变量和作用域”吧!JavaScript的...
    99+
    2023-06-02
  • 一起来了解JavaScript的变量作用域
    目录1.变量作用域的分析2.var关键字3.let和const关键字4.var、let和const的对比总结1.变量作用域的分析 首先,我们先研究一下JavaScript的变量作用域...
    99+
    2024-04-02
  • 理解Golang函数变量的作用域
    理解Golang函数变量的作用域,需要具体代码示例在Golang中,函数是一种特殊的变量类型,可以作为参数传递给其他函数,也可以作为返回值返回。而函数变量的作用域则是指函数变量在代码中可见和可访问的范围。函数变量的作用域可以分为全局作用域和...
    99+
    2023-12-23
    变量作用域 Golang函数 理解 Golang
  • JavaScript如何改变函数作用域
    本篇内容介绍了“JavaScript如何改变函数作用域”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!使用call和apply方法call和a...
    99+
    2023-07-05
  • 理解PHP中的变量作用域和超全局变量
    在学习和使用PHP过程中,变量作用域和超全局变量是两个非常重要的概念。只有充分理解它们,才能更好地利用它们来实现代码的功能。首先,我们来看看变量作用域。在PHP中,变量作用域主要包括全局变量和局部变量。全局变量是指在函数外部声明的变量,它可...
    99+
    2023-05-14
    PHP 变量作用域 超全局变量
  • 如何理解Java内存区域
    如何理解Java内存区域,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Java 内存划分: 在Java内存分配中,java将内存分为:方法区,堆,虚拟机栈,本地方法栈...
    99+
    2023-06-17
  • JavaScript的变量作用域实例分析
    这篇文章主要讲解了“JavaScript的变量作用域实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript的变量作用域实例分析”吧!1.变量作用域的分析首先,我们先研究一...
    99+
    2023-06-29
  • python变量在作用域如何使用
    这篇文章主要介绍“python变量在作用域如何使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“python变量在作用域如何使用”文章能帮助大家解决问题。1、全局作用域变量在局部作用域未定义(赋值或...
    99+
    2023-06-30
  • C++中如何使用变量作用域
    C++中如何使用变量作用域,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。C++变量作用域的使用一定要注意,一般是以一对花括号范围作为一个作用域,例如一下一段函数代码:Voi...
    99+
    2023-06-17
  • VBScript变量的作用域与存活期
    本篇内容主要讲解“VBScript变量”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“VBScript变量”吧!VBScript 变量变量是一种使用方便的占位符,用于引用计算机内存地址,该地址可以...
    99+
    2023-06-09
  • Python变量的作用域详解
    目录总结每个变量都有自己的作用域,在作用域外使用该变量非法 函数体内的变量为函数的局部变量,在函数体外不可使用 >>>def f(): x=5 >&...
    99+
    2024-04-02
  • 怎么掌握js作用域链、内存回收、变量、闭包
    本篇内容介绍了“怎么掌握js作用域链、内存回收、变量、闭包”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一...
    99+
    2024-04-02
  • JavaScript局部变量与全局变量的作用域是什么
    本文小编为大家详细介绍“JavaScript局部变量与全局变量的作用域是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript局部变量与全局变量的作用域是什么”文章能帮助大家解决疑惑,下面...
    99+
    2024-04-02
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作