异步链式编程—promise沉思录

一、promise的组成

1、task:promise要完成的任务;

2、result:处理完的数据;

3、status:状态;

4、fulfill、reject(对应catch)

5、ResolveCallback ErrorCallback promise状态的解释函数

6、resolve:

对promise当前的状态作出解释,已完成的状态立即执行回掉,未完成的状态注册回掉函数;

7、then:前一promise的回掉注册,后一promise的前导;

二、promose状态机:

fulfill、reject:状态改变函数、输入;前导;可以由内部和外部函数执行;

表面接口是task;task内部可能经过多次传递;

ResolveCallback ErrorCallback :状态改变后的输出函数;后续;

三、promise的生命周期(以异步为例)

1、promiseA创建、执行异步task功能;

2、调用then创建中继promise结点(promiseZ),同时将then输入的(promiseX)构造器和promiseZ的(fulfill)打包(promiseA.resolve())传递给promiseA.resolveCallbacks[];

3、promiseA task完成,执行promiseA.fulfill,履行promiseA承若;

4、promiseA.fulfill 调用 后继函数向外传递状态;

5、resolveCallback执行,首先生成promiseX,然后将promiseZ的fulfill注册为promiseX的后继功能;

6、promiseX task完成,执行promiseX 的 fulfill,resolveCallback调用promiseZ的fulfill;

7、promiseZ的状态完成、履行承诺;调用后继的promise模块;

四、函数式编程的环境变量—模拟递归函数调用站

promise异步调用链的构建过程相当于递归调用的构建过程;

promise链的执行过程相当于递归调用的反向执行过程;

理清构造和执行的关键在于搞清楚每一个函数或block的环境变量;

尤其是block,它的环境变量可能横跨几个promise模块;

block的环境变量:

1、self函数代表的promise;

2、函数参量的输入;

3、block生成的环境变量

@discardableResult func then<U>(_ next: @escaping ((T) -> Promise<U>) ) -> Promise<U> {

return Promise<U> { fulfill, reject in

self.catch { (err) in

reject(err)

}.resolve { result in

next(result).catch { (err) in

reject(err)

}.then { (finalResult) in

fulfill(finalResult)

}

}

}

}

普通函数调用通过全局函数和函数调用栈保存环境变量;

block通过block对象保存环境变量;

四、异步编程模型

五、promoie (task)的功能

promiseA:起始的异步功能函数,异步完成后履行promise,调用后继功能;

promiseX:履行then输入的功能,作为promiseA的后继和promiseZ的前导;

由promise构造器(monand的flatmap中的transform)生成;

promiseZ:   负责将promiseX构造器和自身的fulfill打包,通过promiseA的resolve传递给promiseA;同时中继后面的promise;

promiseZ作为promise.then的环境变量;

六、promise构造函数、then、回掉函数管道化

@discardableResult func then<U>(_ next: @escaping ((T) -> Promise<U>) ) -> Promise<U> {

return Promise<U> { fulfill, reject in

self.catch { (err) in

reject(err)

}.resolve { result in

next(result).catch { (err) in

reject(err)

}.then { (finalResult) in

fulfill(finalResult)

}

}

}

}

七、promise、flatMap

trait Monad[M[_]] {

def unit[A](a: A): M[A]

def flatMap[A, B](fa: M[A])(f: A => M[B]): M[B]

将promise对象的构建看成一个过程,

只有transform: @escaping ((T) -> Promise<U>)执行完成,promiseZ才算构造完成;

原文地址:https://www.cnblogs.com/feng9exe/p/11113253.html

时间: 2024-10-15 22:44:20

异步链式编程—promise沉思录的相关文章

jQuery插件编写及链式编程模型

jQuery插件编写及链式编程模型小结 JQuery极大的提高了我们编写JavaScript的效率,让我们可以愉快的编写代码,做出各种特效.大多数情况下,我们都是使用别人开发的JQuery插件,今天我们就来看看如何把我们常用的功能做出JQuery插件,然后像使用jQuery那样来操作DOM.  一.jQuery插件开发快速上手 1.jQuery插件模板 关于jQuery插件的编写,我们可以通过为jQuery.fn增加一个新的函数来编写jQuery插件.属性的名字就是你的插件的名字,其模板如下:

数往知来 JQuery_选择器_隐式迭代_链式编程 &lt;二十&gt;

一.通过js实现页面加载完毕执行代码的方式与jquery的区别 1.通过jquery的方式可以 让多个方法被执行,而通过window.onload的方式只能执行最后一个, 因为最后一次注册的方法会把前面的方法覆盖掉 1. window.onload需要等待页面的所有元素资源比如说img里的图片一些连接等等都下载完毕后才会触发: 2. 而jquery只要页面的标签元素都下载完毕就会触发了 二.$.map(数组,function(ele,index){})函数对数组进行遍历,遍历之后会返回一个新的数

(一一八)利用block实现链式编程

有些时候需要不断地调用方法,如果使用传统方案,需要拿到对象多次调用,例如有一个Ball对象,实现了up.down.left.right四个方法,分别控制球的运动方向,如果要实现球向右再向下,需要这么写: [ball right]; [ball down]; 如果能够按照下面这样写,会更加方便. [[ball right] down]; 要实现这样的功能十分简单,只要每个方法都返回self即可,但是如果调用次数多,会有很多个中括号.如果能改造成后面这样,会更好. ball.right().down

ASP.NET MVC学前篇之扩展方法、链式编程

前言 目的没有别的,就是介绍几点在ASP.NETMVC 用到C#语言特性,还有一些其他琐碎的知识点,强行的划分一个范围的话,只能说都跟MVC有关,有的是外围的知识,有的是包含在框架内的. MVC学前篇字样?有噱头的成分也有真实的成分,所以工欲善其事,必先利其器.器是什么?基础嘛,虽然说MVC框架中涉及到的知识很多很多也不是我一篇两篇能说完的,我能做的就是知道多少就跟大家分享多少,当然了随着时间的推移会完善这个系列. 1扩展方法 扩展方法是C# 3.0特性里的知识,它用在最多的地方是在Linq中,

JavaScript系列:模块化与链式编程

模块化:闭包和和函数作用域(JS没有块级作用域ES6之前)构造模块 1 var man=function(){ 2 var age=12; 3 return { 4 getYear:function(){ 5 return age; 6 }, 7 setYear:function(n){ 8 age=n; 9 } 10 } 11 } 12 13 var peter=man(); 14 document.write(peter.getYear()); //12 15 peter.setYear(2

iOS端JSON转Model链式编程框架SuperKVC使用方法与原理

背景 在client编程中.字典转模型是一个极为常见的问题,苹果提供了KVC来实现NSDictionary到Model的注入,可是KVC仅仅能进行单层浅注入.且无法处理类型转换.key与属性名不正确应.深度注入等问题,笔者从Masonry得到启示,开发了一个通过链式配置注入器实现深度注入.类型转换.key-属性名映射等功能的轻量级注入框架SuperKVC.眼下已经开源到GitHub,点击这里前往.欢迎Star和Fork.欢迎和我一起完好这个框架! 本文将从应用和原理两个角度介绍SuperKVC

链式编程

1 package com.nd.pdca.model; 2 3 public class Manager { 4 5 private String id; 6 private String userId; 7 private String userNo; 8 private String userName; 9 private String unitId; 10 11 public String getUserNo() { 12 return userNo; 13 } 14 15 public

MVVM模式下如何使用ReactiveCocoa响应链式编程&lt;一&gt;

前一阵子公司要求项目从新架构,但又只给不到一个月的时间,这显然是不可能的.但从新架构又是在所难免的,和同事商定后决定一部分交互逻辑比较少的界面先使用MVVM架构,然后慢慢修改.下面整理了一下这次重构的遇到的问题,并希望能给大家一些帮助. 1.ReactiveCocoa的使用 要使用MVVM模式编程收下选择一个框架,当然不仅仅是ReactiveCocoa这一个框架,这里就不多说.当然我也没用过别的,如果哪位看官用过可以多多指教.接下来我就按步骤说了: 第一步:导入ReactiveCocoa框架,建

iOS 利用Block实现链式编程

1. 传统编程 // Person的方法 - (void)eat { NSLog(@"吃饭"); } - (void)learn { NSLog(@"学习"); } - (void)play { NSLog(@"娱乐"); } // 连续做事情 Person *p = [ [Person alloc] init ]; [p eat]; [p learn]; [p play]; 2. 不用Block,实现链式编程 // Person的方法 - (P