JavaScript 如何在后台工作:了解其单线程性质和异步操作

news/2024/9/20 20:46:23/文章来源:https://www.cnblogs.com/aow054/p/18423236
javascript 是网络的支柱,为数十亿网站和应用程序提供动态客户端功能。但您有没有想过 javascript 是如何在后台发挥其魔力的?在这篇文章中,我们将深入研究 javascript 单线程本质的内部工作原理,并探索异步编程的概念。 单线程是什么意思?当我们说 javascript 是“单线程”时,这意味着它有一个调用堆栈。调用堆栈本质上是 javascript 跟踪正在执行的函数的结构。它遵循后进先出 (lifo) 顺序,这意味着最后推送到堆栈的函数将最先完成。以下是其工作原理的示例:function first() { console.log('first function');}function second() { console.log('second function');}first();second();登录后复制在此示例中,first() 函数被添加到堆栈并执行。一旦完成,它就会被弹出,第二个()函数被压入堆栈并接下来执行。虽然单线程语言可能看起来很有限,因为它们一次只能做一件事,但 javascript 巧妙地使用异步机制使其能够模拟多任务处理。 事件循环和异步执行javascript 使用异步执行来处理可能需要很长时间才能完成的操作,例如网络请求、文件 i/o 或计时器。尽管是单线程的,但由于事件循环和回调队列,它可以同时管理多个任务。立即学习“Java免费学习笔记(深入)”; 事件循环事件循环是 javascript 并发模型的核心概念。它的主要职责是管理 javascript 如何处理异步代码执行。其工作原理如下:同步代码首先运行。当 javascript 启动时,它使用调用堆栈以同步方式逐行执行全局范围内的所有代码。异步任务被发送到 web api(如 settimeout、fetch 等)或 node.js api,它们将在后台进行处理。 回调队列是异步操作完成后放置的地方。 事件循环不断检查调用堆栈是否为空。如果堆栈为空,它将从回调队列中取出第一项并将其推送到调用堆栈上,以允许其执行。异步 javascript 的魔力在于事件循环、调用堆栈和回调队列之间的交互。异步操作不会阻塞调用堆栈,这意味着 javascript 可以在等待后台任务完成的同时继续执行其他代码。 示例:使用 settimeout考虑以下带有 settimeout 函数的示例:console.log('start');settimeout(() => { console.log('this runs after 2 seconds');}, 2000);console.log('end');登录后复制以下是逐步发生的事情:javascript 打印“开始”。settimeout 函数被调用,但不是阻塞执行 2 秒,而是发送到 web api,在后台运行。javascript 打印“end”,继续执行而不等待 settimeout 完成。2秒后,settimeout内部的回调函数被放入回调队列中。事件循环检查调用堆栈是否为空(确实如此),然后将回调函数推入堆栈并执行它,打印“this running after 2秒”。 promise 和异步/等待现代 javascript 中处理异步任务的另一种流行方法是通过 promises 和 async/await 语法,这有助于通过避免深层嵌套的回调(也称为“回调地狱”)来提高代码的可读性。promise 表示异步操作的最终完成(或失败)及其结果值。这是一个例子:const promise = new promise((resolve, reject) => { settimeout(() => { resolve('promise resolved!'); }, 1000);});promise.then(result => { console.log(result); // output after 1 second: 'promise resolved!'});登录后复制我们可以使用 then() 来处理 promise 解决时发生的情况,而不是依赖回调。如果我们想以更同步的方式处理异步代码,我们可以使用 async/await:async function asyncExample() { const result = await promise; console.log(result); // Output after 1 second: 'Promise resolved!'}asyncExample();登录后复制这使得代码更干净、更容易理解,允许我们在移动到下一行代码之前“等待”异步任务完成,即使 javascript 在幕后仍然是非阻塞的。 javascript 异步模型中的关键组件调用堆栈:执行同步代码的地方。web api/node.js api:处理异步任务(如网络请求)的外部环境。回调队列:异步任务结果等待推送到调用栈执行的队列。事件循环:协调调用堆栈和回调队列的系统,确保任务按正确的顺序处理。 结论javascript 的单线程特性乍一看似乎有局限性,但其异步功能使其能够有效地管理多个任务。通过事件循环、回调队列和 promise 等机制,javascript 能够处理复杂的非阻塞操作,同时保持直观、同步的编码风格。 以上就是JavaScript 如何在后台工作:了解其单线程性质和异步操作的详细内容,更多请关注我的其它相关文章!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/800721.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用U盘PE重装Windows系统

1、概述 操作系统一般都是安装在硬盘内的,硬盘是一种存储数据的介质,U 盘同样也是一种存储数据的介质,因此也可以把操作系统安装进 U 盘里。 因为大部分 U 盘的性能比较差,不能流畅地运行完整版的操作系统,所以只能安装精简了大部分功能、只保留基本运行环境的简化版操作系…

反射相关API

反射的作用 在不修改源码的情况下,扩展功能。 程序在运行的时期,通过反射机制,获取类的所有内部信息,并且操作类的对象。Class类一个类在堆中只有一个Class对象,这个Class对象包含了类的完整结构信息 反射技术是针对Class对象进行操作,在程序运行的时候,动态获取类中的所…

第二十一讲:MySQL有哪些“饮鸩止渴”提高性能的方法?

第二十一讲:MySQL有哪些“饮鸩止渴”提高性能的方法? 简概引言 ​ 不知道你在实际运维过程中有没有碰到这样的情景:业务高峰期,生产环境的 MySQL 压力太大,没法正常响应,需要短期内、临时性地提升一些性能。 ​ 我以前做业务护航的时候,就偶尔会碰上这种场景。用户的开发…

C++ 数据算数类型

▲ 《C++ Primer》 P30▲ 《C++ Primer》 P38

用户验收测试指南5过渡阶段的UAT

5 UAT的位置 在本书的这一中心章节中,我们将从准备工作的细节中抽身出来,在沉浸于我们的分步方法的细节之前,先从大局出发。UAT 在更大的计划中处于什么位置?它的核心功能和属性是什么?它的总体贡献是什么? 本章涉及的主题作为一系列过渡的 IS 生命周期 过渡规划 作为过渡…

API接口12种安全措施

1. 使用HTTPS:确保数据传输过程中的安全性。2. 使用OAuth2:一种授权框架,用于授权第三方应用访问服务器上的用户数据。3. 使用WebAuthn:一种网络认证标准,用于安全地进行用户认证。4. API进行签名加密:对API请求进行签名以确保请求的完整性和真实性。5. 黑白名单:限制访…

opencascade Bnd_Range源码学习区间计算

opencascade Bnd_Range 前言这个类描述了由两个实数值限定的 1D 空间中的区间。 一个区间可以是无效的,这表示区间中不包含任何点。 方法 1 默认构造函数。创建一个无效区间。 Bnd_Range() ; 2 构造函数。创建最小最大值区间 Bnd_Range(const Standard_Real theMin, const St…

P2414 [NOI2011] 阿狸的打字机

题目思路 将每一个输出的串放入一个 Trie 树中。 考虑离线处理询问 \((x, y)\),对于每一个 \(y\) 集中处理所有的 \(x\),\(y\) 在 Trie 树上走,走过的点标记一下,结果就是 \(x\) 字符串结尾节点在 fail 树上的对应节点的子树的标记数量。 记得在节点离开的时候撤销标记。 代…

0920

线代 舒尔公式,化上三角,下三角,对角阵 范德蒙德行列式 X型行列式,{主对角中下标之和为(2k+1)的两项乘积-副对角中下标之和为(2k+1)的两项乘积【需与前面两项下标号相同】}的连乘 宽对角,a2=4bc,a2≠4bc计组 MAR位数说明存储单元位数 MDR位数说明字长 编译器:将高级语…

DeepFM

参考资料:https://blog.csdn.net/u012328159/article/details/122938925 https://blog.csdn.net/u012328159/article/details/120684544?spm=1001.2014.3001.5501DeepFM FM部分 目前在模型层面做交叉特征的难点主要有以下两个方面:交叉特征的参数独立,强依赖于在样本中的共…

米尔STM32MP2核心板首发新品上市!高性能+多接口+边缘算力

米尔发布基于STM32MP257设计的嵌入式处理器模块MYC-LD25X核心板及开发板。核心板基于STM32MP2系列是意法半导体推出最新一代工业级64位微处理器,采用LGA 252 PIN设计,存储配置1GB/2GB LPDDR4、8GB eMMC,具有丰富的通讯接口,适用于高端工业HMI、边缘计算网关、新能源充电桩、…

Fork+GIT操作

上传分支,在主干,上传完成代码之后,点击新建分支,去一个名字,如1.0.9,双击分支,点击“push”即可将主干所以代码上传到分支上备份一个 合并分支,,双击进入分支,选中要合并的部分,右键点击“Cherry-pick”,再次点击“Push”