来源于个人理解的翻译。

创建一个 promise:

  1. my $p = Promise.new;

可以打印运行 的Promise 状态:

  1. my $p = Promise.new();
  2.  
  3. $p.then({say 'hello, world'});
  4. say $p.status;

上面的promise创建好后, 当 $p 状态为 kept或broken 时, 会执行 then 里面的 匿名函数。

但是, 上面的$p状态总是为: Plannd。

所以, 那个 hello, world 总是不能打印。

那怎么办呢?

Promise 有两个 函数用于更改 promise状态:

  1. . keep
  1. . break

可以改成这样:

  1. my $p = Promise.new();
  2.  
  3. $p.then({say 'hello, world'});
  4. say $p.status;
  5.  
  6. $p.keep;
  7. say 'Result ~ '~$p.result;

结果如下:

  1. C:\p6>perl6 scan_dir.p6
  2. Planned
  3. hello, world
  4. Result ~ True
  5.  
  6. C:\p6>

如果把 keep 改为 break的话, 也会让 匿名函数执行, 同时会引发一个常常:

  1. my $p = Promise.new();
  2.  
  3. $p.then({say 'hello, world'});
  4. say $p.status;
  5. $p.break;
  6. say 'Result ~ '~$p.result;

运行结果如下:

  1. C:\p6>perl6 scan_dir.p6
  2. Planned
  3. hello, world
  4. Tried to get the result of a broken Promise
  5. in block <unit> at scan_dir.p6 line
  6.  
  7. Original exception:
  8. False
  9. in block <unit> at scan_dir.p6 line
  10.  
  11. C:\p6>

注意这里的匿名函数, 当 Promise 执行 kept或 broken 方法时, 会执行它, 最后 promise中的result方法会返回一个值, 这个返回值是传递给 keep 或 break的值或者是then返回了另一个新Promise

的result值(这个值是匿名函数的返回值):

  1. my $p = Promise.new();
  2.  
  3. $p.then({say 'hello, world'});
  4. say $p.status;
  5. $p.keep('Return for Promise');
  6. say 'Result ~ '~$p.result;
  7. say $p.status;

结果:

  1. C:\p6>perl6 scan_dir.p6
  2. Planned
  3. Result ~ Return for Promise
  4. hello, world
  5. Kept
  6.  
  7. C:\p6>
  1. my $p = Promise.new();
  2.  
  3. my $p1 = $p.then({ 'hello, world'});
  4. say $p.status;
  5. #$p.keep('Return for Promise');
  6. $p.keep;
  7. say 'Result ~ '~$p.result;
  8. say $p.status;
  9. say $p1.result;

结果:

  1. C:\p6>perl6 scan_dir.p6
  2. Planned
  3. Result ~ True
  4. Kept
  5. hello, world
  6.  
  7. C:\p6>

如果不传递参数执行 $p.keep 时,  匿名函数执行完后, 用 $p.result 会返回一个 True, 这个true 代理 原来的Promise(这里的$p)执行完毕, 状态为 kept。

这个 then 方法, 其实会自动创建一个新的Promise并返回这个Promise(这里的$p1), then方法中的匿名函数参数就是原来的Promise($p), 看如下代码:

  1. my $p = Promise.new();
  2.  
  3. my $p1 = $p.then(-> $key { say $key.result});
  4. #这里相当于创建了一个新的Promise并返回它
  5. #key 其实就是 $p
  6. $p.keep('This is $p');
  7. #say $p.status;
  8. sleep ;
  9. say $p.status;
  10. say $p1.status;

像一开始所说, Promise.new 创建一个 Promise 时, 默认是不会自动执行的,这时当我们 直接调用 $p.result 想获得 结果时, 程序会一直阻塞(因为我们没有 keep 或 bread 方法告诉这个 promise 让它运行):

  1. my $p = Promise.new();
  2.  
  3. $p.then({say 'hello, world'});
  4. say $p.status;
  5. say 'Result ~ '~$p.result; #这里会一直阻塞
  6. say 'Done'; #上面被阻塞 , 这里不会运行

那么, 我们能不能一开始创建 一个 promise 后, 让它自动去执行呢?

可以, 用 Promist.start() 方法即可。

Perl6多线程2: Promise new/keep/bread/status/result的更多相关文章

  1. Perl6多线程3: Promise start / in / await

    创建一个Promise 并自动运行: my $p = Promise.start({say 'Hello, Promise!'}); 如果把代码改成如下, 我们会发现什么也没打印: ;say 'Hel ...

  2. Perl6多线程4: Promise allof / anyof

    allof   : 所有代码块执行完成后才退出 anyof :只要有一个代码块执行完后就马上退出 要配合 await 一起用: my $p = start {say 'a'}; ;say 'b';} ...

  3. Perl6多线程1 Thread : new / run

    先看一个小例子: ) { #默认参数 say $name; } sub B(:name($name)) { #默认参数为 any say $name; } A(); A(); B(); B(name ...

  4. 异步多线程 ASP.NET 同步调用异步 使用Result产生死锁

    一个方法调用了async方法,要将这个方法本身设计为async. public class BlogController : Controller { public async Task<Act ...

  5. 闲话Promise机制

    Promise的诞生与Javascript中异步编程息息相关,js中异步编程主要指的是setTimout/setInterval.DOM事件机制.ajax,通过传入回调函数实现控制反转.异步编程为js ...

  6. 深入理解jQuery、Angular、node中的Promise

    最初遇到Promise是在jQuery中,在jQuery1.5版本中引入了Deferred Object,这个异步队列模块用于实现异步任务和回调函数的解耦.为ajax模块.队列模块.ready事件提供 ...

  7. 细嗅Promise

    读完这篇文章,预计会消耗你 40 分钟的时间. Ajax 出现的时候,刮来了一阵异步之风,现在 Nodejs 火爆,又一阵异步狂风刮了过来.需求是越来越苛刻,用户对性能的要求也是越来越高,随之而来的是 ...

  8. promise的学习

    为了解决回调地狱的问题,所以出现了promise的设计思想. promise的三种状态: pending 等待状态 resolved 完成状态 rejected 拒绝状态 promise的三种状态,只 ...

  9. 多线程、多进程、协程、缓存(memcache、redis)

    本节内容: 线程: a:基本的使用: 创建线程: 1:方法 import threading def f1(x): print(x) if __name__=='__main__': t=thread ...

随机推荐

  1. PHP内置标准类

    PHP内置标准类 php语言内部,有“很多现成的类”,其中有一个,被称为“内置标准类”. 这个类“内部”可以认为什么都没有,类似这样: class  stdclass{ } 其作用,可以用于存储一些临 ...

  2. chrome 常用插件集锦

    stylish 改变浏览器CSS样式

  3. 第97天:CSS3渐变和过渡详解

    一.渐变 渐变是CSS3当中比较丰富多彩的一个特性,通过渐变我们可以实现许多炫丽的效果,有效的减少图片的使用数量,并且具有很强的适应性和可扩展性. 可分为线性渐变.径向渐变 1. 线性渐变 (grad ...

  4. Idea报错Command line is too long

    需要在该项目文件夹下.idea/workspace.xml中添加 <component name="PropertiesComponent"> ... <prop ...

  5. Contest 6

    A:容易发现这要求所有子集中元素的最高位1的位置相同,并且满足这个条件也是一定合法的.统计一下即可. #include<iostream> #include<cstdio> # ...

  6. C++解析(14):静态成员变量与静态成员函数

    0.目录 1.静态成员变量 2.静态成员函数 3.小结 1.静态成员变量 成员变量的回顾: 通过对象名能够访问public成员变量 每个对象的成员变量都是专属的 成员变量不能在对象之间共享 新的需求: ...

  7. Omeed 线段树

    目录 题面 题解 代码 题面 2.12 - - - 题解 大概还是挺妙的? 首先基础分和连击分互不干扰,所以可以分开统计. 基础分的统计比较简单,等于: \[A \sum_{i = l}^{r} p_ ...

  8. HDU.1846 Brave Game (博弈论 巴什博弈)

    HDU.1846 Brave Game (博弈论 巴什博弈) 题意分析 巴什博奕裸题 博弈论快速入门 代码总览 include <bits/stdc++.h> using namespac ...

  9. day2-python基础

  10. SpringMVC 国际化问题

    1.首先在src文件下添加3个properties文件 a.message.properties message.username=UserName message.password=Password ...