正在學習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協程的詳細內容。更多資訊請關注PHP中文網其他相關文章!