当前位置:  开发笔记 > 编程语言 > 正文

初探swoole协程

正在学习swoole的协程中,协程的特点是看起来象是并发执行。试验一下。本文前提,linux上已安装了swoole。目前的最新版是4.5.9(2020-12-17)构造一个需求,一下创建5个协程,每个协程休眠1到3秒之间的随机数,然...
正在学习swoole的协程中,协程的特点是看起来象是并发执行。试验一下。

推荐免费:swoole

本文前提,linux上已安装了swoole。目前的最新版是 4.5.9(2020-12-17)

构造一个需求,一下创建5个协程,每个协程休眠1到3秒之间的随机数,然后打印出睡眠时间,希望所有的程序结束时,整个耗时是最长3秒。

1.php

foreach (range(1, 5) as $v) {
    go(function () {
        $sleep_time = random_int(1, 3);
        sleep($sleep_time);
        echo "睡眠了" . $sleep_time . "秒\n";
    });}

用php 1.php执行,程序能执行,但是感觉不像是协程,而是同步执行的。整个执行下来远远超过3秒。原来这里有个小bug,应该使用 co:sleep, 这样才会在本协程内睡眠,而不影响整个程序。

2.php

foreach (range(1, 5) as $v) {
    go(function () {
        $sleep_time = random_int(1, 3);
        co::sleep($sleep_time);
        echo "睡眠了" . $sleep_time . "秒\n";
    });}

结果如下:

睡眠了1秒
睡眠了2秒
睡眠了2秒
睡眠了3秒
睡眠了3秒

总之一定是睡眠少的协程先退出,而且,睡眠了同样时间的协程是同时打印出字符的。并且程序结束时的总共耗时就是3秒,说明并发成功。

现在希望5个协程结束后,能打印出hello world!

3.php

foreach (range(1, 5) as $v) {
    go(function () {
        $sleep_time = random_int(1, 3);
        co::sleep($sleep_time);
        $a = random_int(1, 1000);
        echo "睡眠了" . $sleep_time . "秒\n";
    });}echo "hello world!\n";

结果又出问题了,hello world 总是最先打印出来。
所以,这里需要使用协程容器这个东东。

4.php

Co\run(function () {
    foreach (range(1, 5) as $v) {
        go(function ()  {
            $sleep_time = random_int(1, 3);
            co::sleep($sleep_time);
            echo "睡眠了" . $sleep_time . "秒\n";
        });
    }});echo "hello world!\n";

结果如下:

睡眠了1秒
睡眠了2秒
睡眠了3秒
睡眠了3秒
睡眠了3秒
hello world!

这次就能打印出正确结果了,perfect!
swoole的协程还是有点意思的~

以上就是初探swoole协程的详细内容,更多请关注其它相关文章!

推荐阅读
夏晶阳--艺术
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有