正在學(xué)習(xí)swoole的協(xié)程中,協(xié)程的特點(diǎn)是看起來象是并發(fā)執(zhí)行。試驗(yàn)一下。
推薦免費(fèi):swoole
本文前提,linux上已安裝了swoole。目前的最新版是 4.5.9(2020-12-17)
構(gòu)造一個(gè)需求,一下創(chuàng)建5個(gè)協(xié)程,每個(gè)協(xié)程休眠1到3秒之間的隨機(jī)數(shù),然后打印出睡眠時(shí)間,希望所有的程序結(jié)束時(shí),整個(gè)耗時(shí)是最長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執(zhí)行,程序能執(zhí)行,但是感覺不像是協(xié)程,而是同步執(zhí)行的。整個(gè)執(zhí)行下來遠(yuǎn)遠(yuǎn)超過3秒。原來這里有個(gè)小bug,應(yīng)該使用 co:sleep, 這樣才會在本協(xié)程內(nèi)睡眠,而不影響整個(gè)程序。
2.php
foreach (range(1, 5) as $v) { go(function () { $sleep_time = random_int(1, 3); co::sleep($sleep_time); echo "睡眠了" . $sleep_time . "秒n"; });}
結(jié)果如下:
睡眠了1秒 睡眠了2秒 睡眠了2秒 睡眠了3秒 睡眠了3秒
總之一定是睡眠少的協(xié)程先退出,而且,睡眠了同樣時(shí)間的協(xié)程是同時(shí)打印出字符的。并且程序結(jié)束時(shí)的總共耗時(shí)就是3秒,說明并發(fā)成功。
現(xiàn)在希望5個(gè)協(xié)程結(jié)束后,能打印出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";
結(jié)果又出問題了,hello world 總是最先打印出來。
所以,這里需要使用協(xié)程容器這個(gè)東東。
4.php
Corun(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";
結(jié)果如下:
睡眠了1秒 睡眠了2秒 睡眠了3秒 睡眠了3秒 睡眠了3秒 hello world!
這次就能打印出正確結(jié)果了,perfect!
swoole的協(xié)程還是有點(diǎn)意思的~