JavaScript 有一套完全不同于其它语言的对 this 的处理机制。 在五种不同的情况下 ,this 指向的各不相同。...有句话说得很在理 -- 谁调用它,this就指向谁 一、全局范围内 在全局范围内使用this ,它将指向全局对象(浏览器中为 window) var name = 'name1'; console.log...还有几个常见的情况,根据谁调用方法就指向谁的原则,this的指向要细看 // 全局 name var name = 'name1'; var obj = { name: 'name2',...call 或者 apply ,bind 方法时,函数内的 this将会被 显式设置为函数调用的第一个参数。...console.log(name); // 输出更改之后,obj对象中 name的值 console.log(obj.name); },0); ?
JavaScript中执行环境 全局环境 函数环境 eval函数环境 (已不推荐使用) 那么与之对应的执行上下文类型同样有3种: 执行上下文的类型 全局执行上下文 函数执行上下文 eval函数执行上下文...程序代码中基本都会存在函数,那么调用函数,就会进入函数执行环境,对应就会生成该函数的执行上下文。 先插播一个知识点:JS是"单线程"! "单线程"! "单线程"!...JS中管理多个执行上下文 函数编程中,代码中会声明多个函数,对应的执行上下文也会存在多个。...程序执行进入一个执行环境时,它的执行上下文就会被创建,并被推入执行栈中(入栈);程序执行完成时,它的执行上下文就会被销毁,并从栈顶被推出(出栈),控制权交由下一个执行上下文。...因为JS执行中最先进入全局环境,所以处于"栈底的永远是全局环境的执行上下文"。
三.线程切换 进程是拥有资源的集合体,而线程是执行操作的单位。关系很像公司中部门和人员的关系。每个部分都有不同的资源,而部门中的人员则使用资源完成任务。...只保存内核态,中断服务程序执行所必须的状态,包括cpu寄存器,内核堆栈,硬件终端参数等。 同cpu中,中断优先级最高,所以中断切换和进程之前切换并不会同时发生。...五.中断检测和查看 1.检查上下文切换情况 vmstat cs(context switch)是每秒上下文切换的次数 in(interrupt)则是每秒中断的次数 r(Running or Runnable...context switches)每秒自愿上下文切换的次数 是指进程无法获取所需资源,导致的上下文切换,例如I/O、内存等系统资源不足时 nvcswch(non voluntary context switches...)每秒非自愿上下文切换的次数 指进程由于时间片已到,有优先级更高的进程启动等原因,被系统强制调度从而切换。
function () { alert("执行失败"); } }) } //获取上下文路径
js执行上下文的类型 1、全局上下文:是基础,默认上下文类型,任何不在函数内的代码都在全局上下文中。...它会执行两件事:创建一个全局window对象,设置this的值等于这个对象,一个程序只有一个全局上下文环境。 2、函数上下文:每当调用一个函数,就会为这个函数创建一个新的上下文。...每个函数都有自己的上下文,函数上下文可以任意多个。 3、eval函数执行上下文:执行在eval函数内部的函数也有自己的函数上下文。...执行上下文的类型,希望对大家有所帮助。...更多js学习指路:js教程 收藏 | 0点赞 | 0打赏
对于这种情况 python 提供了上下文管理的概念,可以通过上下文管理器处理代码块执行前的准备动作,以及执行后的收尾动作。...使用 with 语句 先来看看不使用上下文管理器的情况 f = open("log.txt", "w") try: f.write("hello") finally: f.close(...) 使用上下文管理器 with open("log.txt", "w") as f: f.write("hello") 当结束语句的时候,Python 会自动的帮我们调用 f.close()方法...自己实现一个上下文管理器 通过enter和exit实现 根据上面 with 语句的原理,我们自己使用类实现一个支持 with 语句的打开文件的类 class File: def __init__...~ 参考文献 廖雪峰的Python教程 - contextlib python with语句上下文管理的两种实现方法 Python 中 with用法及原理
定义 当 JS 引擎开始执行预编译生成的代码时,就会进入到一个执行上下文(Executable Code - 简称 EC)。...可执行代码有几种 前面说到当引擎执行到可执行代码的时候,就会将当前上下文压入上下文栈中。那么可执行的代码又分为几种?...在这里,我们先假设定义执行上下文栈是一个数组: EC = []; 第一种可执行代码 -- 全局代码: 全局类型代码是在加载外部的 js 文件或者本地 标签中的代码。...注意,在全局代码中,并不包含定义在全局环境 function 内的代码。...当所有代码执行完以后,EC 中只会包含全局上下文(global context),当程序退出以后,全局上下文也会退出。
/epel/epel-release-latest-7.noarch.rpm yum -y install sysbench sysstat 1.查看空闲系统上下文切换数据,3秒一次 vmstat 3...in 列:中断次数也上升到了 1k左右,说明中断处理也是问题 说明等待使用cpu的进程太多,导致大量上下文切换,上下文切换导致cpu占用率升高。...4.查看具体应用 -w 参数表示输出进程切换指标,-u 参数则表示输出 CPU 使用指标 pidstat -w -u 3 可以看到sysbench占用了很高的cpu使用率很高,但没有产生多少上下文切换...5.查看多线程,-t显示线程 pidstat -wt 3 可以看到线程占用的很多 6.查看中断信息 /proc/interrupts 这个只读文件中读取,/proc 实际上是 Linux 的一个虚拟文件系统.../proc/interrupts 就是这种通信机制的一部分,用于内核空间与用户空间之间的通信,提供了一个只读的中断使用情况。 watch -d cat /proc/interrupts
当执行 JS 代码时,会产生三种执行上下文 全局执行上下文 函数执行上下文 eval 执行上下文 每个执行上下文中都有三个重要的属性 变量对象(VO),包含变量、函数声明和函数的形参,该属性只能在全局上下文中访问...作用域链(JS 采用词法作用域,也就是说变量的作用域是在定义时就决定了) this var a = 10 function foo(i) { var b = 20 } foo() 对于上述代码,执行栈中有两个上下文...第一个阶段是创建的阶段(具体步骤是创建 VO),JS 解释器会找出需要提升的变量和函数,并且给他们提前在内存中开辟好空间,函数的话会将整个函数存入内存中,变量只声明并且赋值为 undefined,所以在第二个阶段...在提升的过程中,相同的函数会覆盖上一个函数,并且函数优先于变量提升 b() // call b second function b() { console.log('call b fist') }...() { foo = 10 ; console.log(foo) } 因为当 JS 解释器在遇到非匿名的立即执行函数时,会创建一个辅助的特定对象,然后将函数名称作为这个对象的属性,因此函数内部才可以访问到
而进程运行时,需要到寄存器中获得要运行的指令和指令所在内存的位置。...cpu上下文切换,就需要将寄存器中的数据保存到系统内核中,加载新程序的寄存器信息,跳转到计数器所指定的内存位置,开始读取和运行新进程。每次切换需要消耗cpu,繁上下文切换会影响性能。...需要把原先用户态的指令保存,加载内核态的指令到进寄存器,完成指令。这种不会涉及虚拟内存等用户态资源。只是同进程中,为了完成不同权限指令的切换。 进程由内核管理和调度,切换发生在内核态。...上下文中保存了虚拟内存,栈,全局变量等用户空间资源,也保存了内核堆栈,寄存器等内核空间资源。...4.有优先级更高的进程,则当前进程挂起,运行新进程。 5.硬件中断,进程挂起,执行内核中的中断服务。
定义 当 JS 引擎开始执行预编译生成的代码时,就会进入到一个执行上下文(Executable Code - 简称 EC)。...可执行代码有几种 前面说到当引擎执行到可执行代码的时候,就会将当前上下文压入上下文栈中。那么可执行的代码又分为几种?...在这里,我们先假设定义执行上下文栈是一个数组: EC = []; 复制代码 第一种可执行代码 -- 全局代码: 全局类型代码是在加载外部的 js 文件或者本地 标签中的代码。...注意,在全局代码中,并不包含定义在全局环境 function 内的代码。...当所有代码执行完以后,EC 中只会包含全局上下文(global context),当程序退出以后,全局上下文也会退出。
它会执行两件事:创建一个全局的 window 对象(浏览器的情况下),并且设置 this 的值等于这个全局对象。一个程序中只会有一个全局执行上下文。...调用栈列表: - greeting 10.当 greeting() 函数中的所有内容都执行完之后,返回到它的调用行继续执行其余的JS代码。 11.把 greeting() 方法从调用栈列表中删除。...调用栈列表: 空 我们从一个空的调用栈开始,当我们调用一个函数时,它会自动添加到调用栈中,在执行完所有代码之后,它会自动从调用栈中删除。最后,我们也得到了一个空栈。 怎么创建执行上下文?...(在浏览器中, this引用 Window 对象)。 在函数执行上下文中, this 的值取决于该函数是如何被调用的。...对象环境记录器用来定义出现在全局上下文中的变量和函数的关系。 简而言之, 在全局环境中,环境记录器是对象环境记录器。 在函数环境中,环境记录器是声明式环境记录器。
类似,EC 就是一段代码涉及到的场景,在代码运行之前,js engine 会做一些变量内存分配,代码上下文关联的准备工作,这就是 EC。...EC 中会给变量分配一个存储空间,与之对应的数据结构称作 enviroment。 当程序流程需要从当前的 EC 进入另外一个和当前上下文无关的代码片段时,会创建一个新的 EC,并被推入栈中。...由于所有的 js 代码都存在于全局环境中,所以首先会创建 「全局执行上下文」(Global Execution Context),除此之外,js 中每一次的函数调用也会生成 EC,所以栈底肯定会是 全局执行上下文...代码执行到 ln 09 时,因为是对函数的调用,会创建一个新的执行上下文,并置为「当前执行上下文」: foo Execution Context = { this: window,...,y 值在当前的 enviroment 中为 'hellow foo'。
代码都是在执行上下文中运行的。你可以将代码运行与执行上下文的关系类比为进程与内存的关系,在代码运行过程中的变量环境信息都放在执行上下文中,当代码运行结束,执行上下文也会销毁。...而执行栈(Execution Context Stack)是用来管理执行期间创建的所有执行上下文的数据结构,它是一个LIFO(后进先出)的栈,它也是我们熟知的JS程序运行过程中的调用栈。...将全局执行上下文压入执行栈,通常JS引擎都有一个指针running指向栈顶元素:图片JS引擎会将全局范围内声明的函数(foo)初始化在全局上下文中,之后开始一行行的执行代码,运行到console就在running...PS:当然,当调用log函数时,也是要新建函数上下文并压栈到调用栈中的。这里为了简单流程,忽略了log上下文的创建过程。...总结本文关于执行上下文的理论知识比较多,不容易马上吸收理解,建议你逐渐消化、反复阅读理解。当你熟悉了执行上下文和词法环境,相信去理解认识更多JS特性和概念时,会更加轻松容易。
执行上下文和执行栈是js执行机制中的两个概念,要想深入的对js进行理解与应用,理解js的机制很重要,下面来说一下什么是执行上下文,什么又是执行栈。...执行上下文 简而言之,执行上下文就是当前 JavaScript 代码被解析和执行时所在环境的抽象概念, JavaScript 中运行任何的代码都是在执行上下文中运行。...一个程序中只能存在一个全局执行上下文。 函数执行上下文是指在每次调用函数时,都会为该函数创建一个新的执行上下文,这就是函数执行上下文,他可以有无数个。有多少个函数就有多少个函数执行上下文。...每个函数都拥有自己的执行上下文,但是只有在函数被调用的时候才会被创建。一个程序中可以存在任意数量的函数执行上下文。每当一个新的执行上下文被创建,它都会按照特定的顺序执行一系列步骤。...Eval 函数执行上下文:是指运行在 eval 函数中的代码创建的自己的执行上下文。
Session的典型应用: 防止用户非法登录到某个页面。 网上商城的购物车 保存用户登录信息 注:多个请求要用的东西放在session中,多个会话之间要用的东西放在上下文中。...() 返回Session对象中存储的每一个属性对象,其结果为一个类举的实例. 3. getCreationTime() 返回Session被创建的时间.最小单位为千分之一秒. 4.getId() 此方法返回惟一的标识...答:1.会话是由容器来创建的,长时间不用,容器会在30分钟后将它销毁,它是不能一直存放在服务器中的。...3,对于某一个会话设置有效时间,在Servlet中用session.setMaxAge(秒)来设置 上下文的作用 利用上下文对象可以实现多个用户之间的数据共享。 上下文对象如何创建的?...答: 如果在一个应用中有多个Servlet和JSP都使用的变量,以后还可能被修改,就可以考虑用上下文参数 在web.xml中配置: level
一、执行上下文 单线程 同步执行,只有栈顶的上下文处于执行中,其他上下文需要等待 全局上下文只有唯一的一个,它在浏览器关闭时出栈 函数的执行上下文的个数没有限制 每次某个函数被调用,就会有个新的执行上下文为其创建...,即使是调用的自身函数,也是如此。...---- 二、作用域 1、变量作用域 全局变量:在全局声明的变量,任何地方都可以访问 局部变量:在函数里声明的变量,只有函数里内访问 ——几个注意点: 1)声明局部变量必须用var,不然会污染全局变量...—— return 2、函数作用域 js没有块级作用域,而有函数作用域。 函数作用域是指:在函数内声明的所有变量在函数体内是始终可见的。...---- 三、闭包 什么是闭包 参考:学习Javascript闭包(Closure)——阮一峰 有权访问另一个函数作用域中的变量的函数 定义在一个函数内部的函数 function f1(){
上下文环境的初始化在代码执行前完成 JS有三种作用域:全局作用域、函数作用域、eval作用域(不常用,不做介绍)。...在JS代码执行前,首先会对这三种作用域进行上下文环境的准备工作,准备内容如下: 全局作用域的上下文准备工作 将全局变量设为undefined 将函数表达式的值设为undefined 为函数声明直接赋值...JS运行时才能确定,而全局作用域中的this在准备上下文环境的时候就确定了(window)。...因为在代码运行前的准备上下文环境过程中,函数的初始化已经完成,所以运行时无论函数调用语句在哪儿,JS编译器都能调用这个函数。 若采用函数表达式来定义函数,则函数定义一定要在函数调用语句之前!...JS中作用域只有三种:全局作用域、函数作用域、eval作用域。除此之外就没有作用域了!如:for、if、while等都不是独立的作用域! 因此在里面定义的局部变量都属于其所属的外层作用域。
这篇文章中,我将深入探讨JavaScript中的一个最基本的部分,即执行上下文(或称环境)。...在上面的例子中,函数可以访问在其当前上下文之外声明的变量,但是外部上下文无法访问(函数)其中声明的变量/函数。为什么会这样?这段代码究竟是如何评估的?...如果在全局代码中调用一个函数,程序的顺序流就进入被调用的函数,创建一个新的执行上下文并将该上下文推送到执行栈的顶部。 如果你在当前函数中调用另外一个函数,则会发生同样的事情。...此扫描的结果将称为executionContextObj中的variableObject。 以下是解释器如何评估代码的伪概述: 找些代码来调用一个函数 在执行函数代码之前,创建执行上下文。...扫描上下文以获取函数声明: 对于找到的每个函数,在变量对象(或活动对象)中创建一个属性,该属性是确切的函数名称,该函数具有指向内存中函数的引用指针。 如果函数名已存在,则将覆盖引用指针值。
js如何创建执行上下文 1、创建一个执行分为两个阶段:创建阶段和执行阶段。 2、创建阶段会发生三件事:绑定this指向,也被称为 This Binding、创建词法环境组件、创建变量环境组件。...this 指向 LexicalEnvironment = { ... }, // 词法环境 VariableEnvironment = { ... }, // 变量环境 } 以上就是js...创建执行上下文的方法,希望对大家有所帮助。...更多js学习指路:js教程 收藏 | 0点赞 | 0打赏
领取专属 10元无门槛券
手把手带您无忧上云