[教程]ZAsync 异步编程教程之七:在后台线程中 async/await

在上一节中,我们做了一个简单的 async/await 的例子,这一节我们继续对其进行更详细的解析。 前面我们已经说过,async/await 模式是一种协同式的多任务执行机制,要求处理代码在等待一个操作时(如磁盘IO、网络IO等),显式调用对应的接口(对于 ZAsync ,为 TZAsync.Yield)。否则使用

[教程]ZAsync 异步编程之四:关于匿名函数和线程变量

[匿名函数] 在 Delphi 中,匿名函数实际上是一个接口,这一点我们在前面的文章中已经做出了明确的提示。从前面的分析我们可以看出: 1、在匿名函数中使用的局部变量,实际内存是对应的结构成员的位置,而不是当前函数栈上的位置。 2、如果一个接口局部变量被匿名函数引用,那么应该在用完后,设置为空,以便减小引用计数,避免内

[教程]ZAsync异步编程之五:IZAsyncInvoker的执行链条

ZAsync 简化了异步编程模型的设计,做了以下强制约定: 异步作业执行可以在主线程或后台线程中执行 异步作业执行函数退出后的操作,如果是用 async/await 调用,则其在原线程中执行,而其它后台线程的异步作业,只能在主线程中运行,以方便访问主线程界面元素,减少出错的几率。 为了方便大家了解 ZAsync 异步编

[教程]ZAsync 异步编程之三:我们对异步编程的一些观点

异步编程对于开发人员来说,实际上是一个又爱又恨的东西,用好了很舒服,用不好很麻烦。异步编程中,异步操作代码的本身是在一个后台线程或当前线程中延迟调用。而大家说异步编程的几种不同的处理方式,实际上是指对异步处理完成后,如何处理后续的步骤,本质上都是回调处理函数,但操作各有不同: 直接设置回调函数 订阅机制:订阅异步作业通

[教程]使用 TZAsync 进行异步编程教程之二:TZAsync 解决了什么问题

在上一节教程的例子中,我们演示了一个简单的异步编程的例子。 我们请大家首先阅读 Delphi 自带的异步编程模型,那么它存在的问题: 生命周期问题: 没有和现有的组件体系结合,如果 BeginInvoke 引发的异步调用,返回回调时异步作业的创建者被释放,那么如果我们在其中访问创建者相关的实例,就有可能出现问题。 异步