【一】.基本用法
首先看看官方对send方法的解释:
Sets the return value of the yield expression and resumes the generator (unless the generator is already closed).设置yield表达式的返回值并恢复生成器(除非生成器已经关闭)。
个人理解的说明:
send方法将自己的发送的值传递给上一个yield表达式的结果,然后继续隐式的继续执行下一个yield并接收下一个yield的值
带着上面的个人理解来看第一个例子:
function gen()
{
$ret = (yield '1');
var_dump($ret); //Hi1只会在这里打印的,这个值不会返回给send
$ret = (yield '2');
var_dump($ret); //Hi2只会在这里打印的,这个值不会返回给send
}
$gen = gen();
var_dump($gen->current());
var_dump($gen->send('Hi1'));
var_dump($gen->send('Hi2'));输出结果:
string(1) "1" string(3) "Hi1" string(1) "2" string(3) "Hi2" NULL
解释执行过程:
首先$gen->current()一定是执行当前的第一个迭代输出1毫无疑问,然后$gen->send('Hi1') 将Hi1这个值传递给上一个yield表达式的结果,也就是$ret = (yield '1');那么此时ret的值变为了Hi1,所以输出Hi1,然后send会恢复去执行下一个yield,下一个yield的返回值是2,这个2返回给send了,于是打印输出2。然后$gen->send('Hi2') 将Hi2这个值传递给上一个yield表达式的结果,并且在生成器中打印了,继续走向下一个yield,但是没有下一个yield,因此返回了null给send方法。
【二】.迭代器被创建的时候一个renwind()方法已经被隐式调用,而且忽略表达式的返回值,因此send拿到的是yield就是第二个yield
首先看下面的代码:
function gen()
{
$ret = (yield '1');
$ret = (yield '2');
}
$gen = gen();
var_dump($gen->send('Hi1'));输出结果:
string(1) "2"
因此我们通过send的特性可以实现简单的生成器收发消息
function gen()
{
$ret = (yield '1');
echo 'recv:'. ($ret) . PHP_EOL;
$ret = (yield '2');
}
$gen = gen();
echo $gen->current() . PHP_EOL;
echo ($gen->send('Hi1')) . PHP_EOL; 通过经纬度转换为城市名称,并获得城市的编号,通常在全国类型的商城中比较通用。//经纬度转城市名称(返回城市id,城市名称) //$ak开发密钥,$lat纬度,$lng经度,$type返回数据类型 public function getCityName($ak,$lat,$lng)...
开启错误提示代码:ini_set("display_errors", "On"); error_reporting(E_ALL | E_STRICT);关闭错误提示代码:error_reporting(E_ALL ^&n...
首先看看以下代码:代码1:<?php $a=0.1; $b=0.7; if($a+$b==0.8) { echo "1"; } else{ echo "2"; } ?>代码2:<?php &n...
(1).前端文件:<form action="upload.php" method="post" enctype="multipart/form-data"> &...
(1).config.php 配置文件<?php /** * RabbitMQ_Config */ $config = [ 'host' => ...
(1).学习的目标:学会创建父子进程,并且能够区分当前进程是父还是子;了解父进程执行过程,子进程执行过程;能够用多进程执行任务(2).相关函数学习: (2.1)pcntl_fork()执行时: &nbs...