
JavaScript函数的执行并不是一调用就立刻运行内部代码那么简单,它背后有一套完整的执行机制。理解这个过程,有助于我们掌握变量提升、作用域、闭包等核心概念。函数执行的核心环节包括:函数被调用时创建执行上下文、进入执行栈、变量环境初始化、this绑定以及代码执行。
函数执行前:创建执行上下文
每当一个函数被调用时,JavaScript引擎会为该函数创建一个执行上下文(Execution Context)。这个上下文是函数运行的环境,包含了函数执行所需的所有信息。
执行上下文的创建分为两个阶段:
词法环境(Lexical Environment)初始化:解析函数内部的变量声明和函数声明,进行变量提升(Hoisting)。var声明的变量会被初始化为undefined,let/const声明的变量进入“暂时性死区”,函数声明则直接完整提升。 this绑定:根据函数的调用方式确定this的值。例如,对象方法中的this指向调用者,普通函数调用中this指向全局对象(非严格模式)或undefined(严格模式)。
执行上下文入栈与执行
JavaScript采用调用栈(Call Stack)管理函数执行。每次函数调用,其执行上下文被压入栈顶;函数执行完毕后,上下文从栈中弹出。
举个例子:
function foo() {
console.log(‘start’);
bar();
console.log(‘end’);
}
function bar() {
console.log(‘bar’);
}
foo();
执行流程如下:
全局上下文入栈 调用foo(),foo的执行上下文入栈 执行到bar(),bar的执行上下文入栈 bar执行完,出栈 foo继续执行后续语句,完成后出栈
作用域链与变量查找
函数在执行过程中访问变量时,会沿着作用域链(Scope Chain)从内向外查找。作用域链是在函数定义时确定的,基于函数的嵌套关系。
OpenMP并行程序设计 WORD版
本文档主要讲述的是OpenMP并行程序设计;OpenMP是一个编译器指令和库函数的集合,主要是为共享式存储计算机上的并行程序设计使用的。目前支持OpenMP的语言主要有Fortran,C/C++。 OpenMP在并行执行程序时,采用的是fork/join式并行模式,共享存储式并行程序就是使用fork/join式并行的。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看
0 查看详情
例如:
function outer() {
let a = 1;
function inner() {
console.log(a); // 能访问到outer中的a
}
inner();
}
outer();
inner函数的作用域链包含自身的词法环境和outer函数的词法环境。即使outer已经执行完毕,inner仍能通过作用域链访问a,这就是闭包的基础原理。
函数执行结束:上下文出栈与内存回收
函数执行完成后,其执行上下文从调用栈中弹出。如果没有任何引用指向该函数内部的变量(比如没有闭包保留引用),这些变量将被标记为可回收,等待垃圾回收机制处理。
但如果有闭包存在,比如内部函数被外部引用,那么外层函数的变量环境仍需保留,不会立即释放。
基本上就这些。理解函数执行过程,关键在于把握执行上下文的创建、作用域链的形成以及调用栈的运作方式。这些机制共同支撑了JS的动态执行行为。不复杂但容易忽略细节。
以上就是js函数执行过程的探究的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/870545.html
微信扫一扫
支付宝扫一扫