PHP yield 异步操作结合同步业务代码例子

PHP中文网
リリース: 2016-05-23 17:09:31
オリジナル
2707 人が閲覧しました

<?php
/*
 * yield 异步操作结合同步业务代码例子
 * @author Corz*/
//业务同步代码
function syncCode()
{
    var_dump((yield [&#39;dns&#39;, &#39;www.baidu.com&#39;]));
    var_dump((yield [&#39;lag&#39;, 200]));
    var_dump((yield [&#39;dns&#39;, &#39;www.taobao.com&#39;]));
    var_dump((yield [&#39;sql&#39;, &#39;show tables&#39;]));
}
//异步调用器
function asyncCaller(Generator $gen)
{
    $r = $gen->current();
    if (isset($r)) {
        switch ($r[0]) {
            case &#39;sql&#39;:
                AsyncMysql::getInstance()->query($r[1], 
                    function ($retval) use($gen) {
                        $gen->send($retval);
                        asyncCaller($gen);
                    });
                break;
            case &#39;dns&#39;:
                swoole_async_dns_lookup($r[1], 
                    function ($host, $ip) use($gen) {
                        $gen->send([$host, $ip]);
                        asyncCaller($gen);
                    });
                break;
            case &#39;lag&#39;:
                swoole_timer_after($r[1], 
                    function () use($gen, $r) {
                        $gen->send(&#39;lag &#39; . $r[1] . &#39;ms&#39;);
                        asyncCaller($gen);
                    });
                break;
            default:
                $gen->send(&#39;no method&#39;);
                asyncCaller($gen);
                break;
        }
    }
}

asyncCaller(syncCode());

/**
 * 异步mysql类
 */
class AsyncMysql
{

    /**
     * @var mysqli
     */
    protected $db = null;

    /**
     * @var callable
     */
    protected $callable = null;

    public static function getInstance()
    {
        static $instance = null;
        return isset($instance) ? $instance : ($instance = new self());
    }

    public function __construct()
    {
        $this->db = new mysqli(&#39;127.0.0.1&#39;, &#39;root&#39;, &#39;123456&#39;, &#39;mysql&#39;);
        swoole_event_add(swoole_get_mysqli_sock($this->db), [$this, &#39;onQuery&#39;]);
    }

    public function onQuery($db_sock)
    {
        $res = $this->db->reap_async_query();
        call_user_func($this->callable, $res->fetch_all(MYSQLI_ASSOC));
    }

    /**
     * @param string    $sql
     * @param callable  $callable
     */
    public function query($sql, callable $callable)
    {
        $this->callable = $callable;
        $this->db->query($sql, MYSQLI_ASYNC);
    }
}
ログイン後にコピー

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のおすすめ
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート