首页
/ 掌控异步计算的新纪元:Me

掌控异步计算的新纪元:Me

2024-05-31 23:30:56作者:胡唯隽

在云端应用中,异步编程占据了代码的主导地位,而嵌套的闭包或块往往给维护、可读性和控制带来挑战。为了应对这个问题,我们引入了一个神奇的解决方案——Me,一个轻量级(少于200行)的软件库,它通过链式调用来替代传统的嵌套方式,让您的代码更加清晰有序。

简单示例

传统的做法是这样的:

MyAPI.login {
    //Do your stuff and then request posts...
    MyAPI.posts {
        //Do your stuff and then request comments...
        MyAPI.comments {
            //Do your stuff and then request likes...
            MyAPI.likes {
                //We are done here
            }
        }
    }
}

使用Me后,情况会变得截然不同:

Me.start { (me) in
    MyAPI.login {
        //Do your stuff and then request posts...
        me.runNext()
    }
}.next { (caller, me) in
    MyAPI.posts {
        //Do your stuff and then request comments...
        me.runNext()
    }
}.next { (caller, me) in
    MyAPI.comments {
        //Do your stuff and then request likes...
        me.runNext()
    }
}.next { (caller, me) in
    MyAPI.likes {
        //We are done here
        me.end()
    }
}.run()

如您所见,代码流的转移得到了很好的解决,开发者对代码的控制力更强了。

Me 是什么?

Me 对象是一个代理,用于持有当前正在执行的代码块和接下来要执行的代码块。它的工作流程如下:

  • 使用 Me.start 开始,添加第一个代码块,然后继续用 .next 添加后续代码块。
  • .next 方法接收两个 Me 对象参数,一个是调用者,另一个则是当前处理中的代码块。
  • 使用 .run() 命令启动第一个代码块,必须放在链条的末尾。

在每个代码块内,你需要指示何时执行下一个代码块,这通过 runNext()end() 来实现:

  • me.runNext() 被用于调用下一个代码块,当异步调用返回且准备运行下一段代码时,应调用该命令。
  • me.end() 表示结束链条并释放所有与之关联的 Me 对象和代码块。

优点

  • 易于阅读
  • 易于维护
  • 不需要创建自定义代理(如 Promise),只需重构嵌套块,并将其拆分为不同的 .next 代码块。
  • 基于安全的 Grand Central Dispatch 构建,允许您在自己的队列中运行代码。
  • 允许直接跳转到特定代码块,查看调用者名称。
  • 允许您在 parameters 字典中设置所有参数。

缺点

  • 相比嵌套代码,每段代码可能会长2-3行。
  • 必须记得在适当位置添加 runNext()end(),否则可能导致下一个代码块不执行或内存未被释放。
  • 参数不能直接作为块参数传递,需通过 parameters 字典指定。

保持联系

如果您在应用中使用了 Me,我们非常想知道,请发送电子邮件至 <pasquale.ambrosini@gmail.com>

现在,是时候拥抱更清晰、更可控的异步编程了,让 Me 成为你的助手,让代码编写和维护变得更加愉快!

热门项目推荐

项目优选

收起
Python-100-DaysPython-100-Days
Python - 100天从新手到大师
Python
266
55
国产编程语言蓝皮书国产编程语言蓝皮书
《国产编程语言蓝皮书》-编委会工作区
65
17
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
196
45
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
53
44
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
268
69
qwerty-learnerqwerty-learner
为键盘工作者设计的单词记忆与英语肌肉记忆锻炼软件 / Words learning and English muscle memory training software designed for keyboard workers
TSX
333
27
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
896
0
advanced-javaadvanced-java
Advanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。
JavaScript
419
108
MateChatMateChat
前端智能化场景解决方案UI库,轻松构建你的AI应用,我们将持续完善更新,欢迎你的使用与建议。 官网地址:https://matechat.gitcode.com
144
24
HarmonyOS-Cangjie-CasesHarmonyOS-Cangjie-Cases
参考 HarmonyOS-Cases/Cases,提供仓颉开发鸿蒙 NEXT 应用的案例集
Cangjie
58
4