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 的协程还是有点意思的~

本作品采用《CC 协议》,转载必须注明作者和本文链接
未填写
文章
58
粉丝
11
喜欢
63
收藏
105
排名:485
访问:1.8 万
私信
所有博文
社区赞助商