正在学习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的协程还是有点意思的~
Atas ialah kandungan terperinci 初探swoole协程. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!