将 Golang 延迟概念实现到 Javascript 中

将 golang 延迟概念实现到 javascript 中

在 go 中,defer 语句推迟函数的执行,直到周围的函数返回。这是一个简单的例子:

package mainimport "fmt"func main() {    fmt.println("start")    defer fmt.println("defer 1")    defer fmt.println("defer 2")    fmt.println("end")}

在这个例子中,主函数正常执行,但所有延迟函数在函数退出时都以相反的顺序执行。所以输出将是:

startenddefer 2defer 1

现在,向 javascript 添加 defer 关键字需要大量工作。但这就是我喜欢 js 的原因 – 它是如此通用,您可以实现其他编程语言的功能,而无需接触编译器。

但首先,我们为什么需要这个?

编程中类似延迟的功能有许多有用的用例,例如:

资源清理:清理文件句柄等资源。事务操作:在发生错误时回滚更改,例如恢复数据库或状态更新。日志记录:在操作结束时添加日志记录。ui 状态管理:处理后重置状态。

这样的例子还在继续……

立即学习“Java免费学习笔记(深入)”;

现在,让我们深入了解有趣的部分:我们在 javascript 中实现 defer。

class deferer {  static stack = [];  static wrapped = false;  static defer(fn) {    this.stack.push(fn);    if (!this.wrapped) {        throw new error("can't call defer wihtout wrapping the function with deferer.wrapper")    }  }  static execute() {    while (this.stack.length > 0) {      const fn = this.stack.pop();      try {        fn();      } catch (err) {        throw new error('error in deferred function:', err);      }     }    this.wrapped = false;  }  static wrapper = (cp) => (...args) => {        if(this.wrapped) throw new error("nested deferers are not supported");        this.wrapped = true;        try {         const v = cp(...args)         this.execute()         return v;        } finally {          this.wrapped = false;        }  }}const mydeferedfunction =deferer.wrapper((a, b, c) => {  console.log("start of function", a, b, c);  deferer.defer(() => console.log("deferred: function 1"));  deferer.defer(() => console.log("deferred: function 2"));  console.log("end of function", a, b, c);});mydeferedfunction(8,8,8)

输出:

Start of function 8 8 8End of function 8 8 8Deferred: Function 2Deferred: Function 1

正如预期的那样,延迟函数在主函数完成后以相反的顺序执行。

谢谢,

艾哈迈德

以上就是将 Golang 延迟概念实现到 Javascript 中的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1499584.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 21:53:11
下一篇 2025年12月19日 21:53:22

相关推荐

  • 发布了一个用于 JS/TS 异步进程同步执行的库

    我发布了一个名为sync-actions 的库,它允许异步进程在 javascript/typescript 中同步执行。特别是在 typescript 中,您可以以类型安全的方式调用定义的函数。它适用于您想要在您不希望(或不能)标记为异步的函数中执行异步进程的情况。 特征 利用 node.jswo…

    2025年12月19日
    000
  • Integration Testing: Ensuring Seamless Software Interactions

    什么是集成测试 集成测试是软件测试生命周期中的关键阶段,旨在确保系统的不同模块按预期协同工作。单元测试验证各个组件,而集成测试则侧重于这些组件之间的通信和交互。本博客探讨了集成测试的重要性、类型、工具、挑战和最佳实践,全面了解其在交付高质量软件中的作用。 为什么集成测试很重要? 集成测试有助于识别组…

    2025年12月19日
    000
  • JavaScript:编程语言的“英语”

    虽然我是后端开发人员,但我的主要编程语言是 JavaScript,原因很简单:JavaScript 和英语一样,有许多不一致、历史怪癖和缺陷,但它无处不在。 阿特伍德定律:“任何可以用 JavaScript 编写的应用程序最终都将用 JavaScript 编写”。 几乎每部手机和计算机上都有一个 J…

    2025年12月19日
    000
  • 掌握 JavaScript 装饰器

    javascript 装饰器是一项强大的功能,可以简化代码并增强可读性,特别是在处理复杂的应用程序时。在这篇博客中,我们将通过实际示例来简化装饰器,使高级开发人员更容易有效地实现它们。 什么是 javascript 装饰器? 装饰器是一种用于修改类及其成员的特殊语法。它们是可应用于类、方法或属性的函…

    2025年12月19日
    000
  • JavaScript 循环综合指南

    JavaScript 循环结构 这份指南将深入探讨 JavaScript 中各种循环结构及其用法,并附带示例代码。 1. for 循环 当循环次数已知时,for 循环是最佳选择。 语法: for (let i = 0; i < 10; i++) { // 代码块} 示例: for (let i…

    2025年12月19日
    000
  • 掌握 JavaScript 中的 JSON 处理:解析和字符串化

    JavaScript JSON 处理:解析与字符串化详解 JSON (JavaScript 对象表示法) 是一种轻量级的数据交换格式,易于人类阅读和编写,也易于机器解析和生成。JavaScript 内置方法可实现 JSON 字符串与 JavaScript 对象的相互转换。 1. 解析 JSON 字符…

    2025年12月19日
    000
  • JavaScript 中字符串操作综合指南

    javascript 中的字符串操作 字符串操作是 javascript 中文本处理的核心方面。 javascript 提供了一组丰富的内置方法和技术来处理和转换字符串。 1.创建字符串 javascript 中的字符串可以使用单引号 (‘)、双引号 (“) 或反引号(` 用…

    好文分享 2025年12月19日
    000
  • 我如何开始作为 MERN 堆栈开发人员的旅程

    简介: “我记得第一次遇到 MERN Stack 这个术语时——MongoDB、Express.js、React.js 和 Node.js。我不知道这些工具是什么,但我知道如果我能掌握它们,我就能够构建一些令人惊叹的网络应用程序。这是我如何从初学者到深入研究 MERN Stack 开发世界的故事。”…

    2025年12月19日
    000
  • 了解 Protocol Buffers:JSON 的快速替代方案

    在数据交换领域,json(javascript 对象表示法)一直是人们的最爱。它简单、易读,并且可以跨平台无缝运行。对于许多用例来说,json 已经“足够好”。但随着系统规模的扩大以及对速度和效率的需求的增加,json 基于文本的格式可能会成为瓶颈。 这就是 protocol buffers (pr…

    2025年12月19日
    000
  • 高级 JavaScript 概念 Promise、async/await 和 try-catch

    第 8 天:高级 javascript 概念 日期:2024 年 12 月 15 日 欢迎来到第八天!今天,我们探讨一些最强大、最先进的 javascript 概念,这些概念可以提高您的编程技能。其中包括现代 es6 功能、使用 promise 和 async/await 的异步编程,以及使用 tr…

    2025年12月19日
    000
  • 大 O 符号

    它是一种表示法,决定算法运行的速度有多快或多慢。这个速度不是由秒决定的,而是由算法的运行时间随着元素的增加而增加多少决定的。 大o是时间和大小的关系。在整篇文章中,您将看到包含这些度量的图表,并且您将在实践中更好地理解它们。我们有两种类型的复杂性(空间和时间)。 时间复杂度: 确定执行与输入大小成正…

    2025年12月19日 好文分享
    000
  • 如何通过代码分割提高 React 应用程序的性能

    随着 react 应用程序的大小和复杂性不断增长,其 javascript 包的大小会显着影响性能,尤其是在较慢的网络或设备上。缓解此问题的一种有效方法是通过代码拆分,这是一种将应用程序分解为更小的块的技术。这些块按需加载,减少了初始加载时间并提高了整体性能。 在本文中,我们将探讨什么是代码分割、为…

    2025年12月19日
    000
  • Documenso 和 aws-smage-upload 示例之间的 Spload 功能比较

    在本文中,我们将比较 documenso 和 aws s3 图像上传示例之间将文件上传到 aws s3 所涉及的步骤。 我们从 vercel 提供的简单示例开始。 示例/aws-s3-image-upload vercel 提供了一个将文件上传到 aws s3 的良好示例。 此示例的自述文件提供了两…

    2025年12月19日
    000
  • 掌握重做快捷键:生产力指南

    在当今快节奏的数字世界中,掌握键盘快捷键对于提高生产力和效率至关重要。虽然许多人熟悉复制、粘贴和撤消等常见快捷键,但重做快捷键通常没有得到应有的关注。本博客详细探讨了重做快捷方式,包括其用法、变体以及帮助您更智能地工作的提示。 重做快捷键是什么? 重做快捷键是撤消“撤消”操作的快速方法,让您无需手动…

    2025年12月19日
    000
  • 为什么 React 中的 Props 是不可变的?

    为什么 react 中的 props 是不可变的? 在 react 中,props 被认为是不可变的,因为它们的值无法更改。 props 主要用于将数据从父组件传递到子组件。 react 确保 props 保持不可变,以防止任何组件意外或故意修改从其父级接收的数据。这种不变性强化了单向数据流的概念。…

    2025年12月19日
    000
  • 使用 Nextjs Tailwind CSS、Prisma、Open AI 和 Clerk 构建的 AI 旅行规划应用程序

    人工智能旅行规划师 使用 next.js 15、tailwind css、prisma、open ai 和 clerk 构建的 ai 旅行规划应用程序。功能包括用户注册、登录、生成旅行计划、查看所有旅行计划和删除行程。在开发过程中接受贡献。 入门 克隆存储库:git clone https://gi…

    2025年12月19日
    000
  • 感谢您的记忆

    认识我的人都知道我的记忆力绝对是垃圾。任何缺少 monty python 对白和 90 年代另类摇滚乐队曲目列表的内容,我都无法接受。 然而,对我们来说幸运的是,计算机在记住事物方面的能力要强得多。 概念 我们今天讨论的技术称为记忆化。让我们从讨论纯函数开始。纯函数背后的想法是,无论你给它什么输入,…

    2025年12月19日
    000
  • LeetCode 的 JavaScript 时代实际上填补了空白

    大多数编码挑战都会教你解决难题。 leetcode 的 30 天 javascript 学习计划做了一些不同的事情:它向您展示了拼图如何变成砖块,准备好构建现实世界的项目。 这种区别很重要。当您解决典型的算法问题时,您正在训练您的思维进行抽象思考。但是,当您实现去抖1函数或构建事件发射器2时,您正在…

    2025年12月19日
    000
  • 在 React JS 项目中设置 Tailwind CSS

    如果您还没有 react 应用程序,请创建一个: npx create-react-app my-appcd my-app 安装 tailwind css运行以下命令安装 tailwind css 及其依赖项: npm install -d tailwindcss postcss autoprefi…

    2025年12月19日
    000
  • agilbo 让敏捷项目管理变得轻松

    在当今快节奏的商业世界中,适应性和效率对于成功至关重要。企业不仅必须提供高质量的产品,还必须快速响应不断变化的需求。敏捷产品项目管理已成为一种改变游戏规则的方法,使团队能够协作、适应并交付卓越的结果。 Agilibo 凭借其创新平台,提供了完美的工具包来支持企业采用敏捷方法并实现其目标。 了解敏捷产…

    2025年12月19日
    000

发表回复

登录后才能评论
关注微信