官方解釋yieldphp
yield生成器是php5.5以後出現的,官方文檔這樣解釋:yield提供了一種更容易的方法來實現簡單的迭代對象,相比較定義類實現 Iterator 接口的方式,性能開銷和複雜性大大下降。mysql
生成器的核心是一個yield關鍵字,一個生成器函數看起來像一個普通的函數,不一樣的是:普通函數返回一個值,而一個生成器能夠yield生成許多它所須要的值。生成器函數被調用時,返回的是一個能夠被遍歷的對象。sql
yield和return有點相似,不過不一樣的是,return會返回值而且終止代碼的執行,而yield會返回一個值給循環調用今生成器的代碼而且只是暫停執行生成器函數。
數據庫
這裏順便給你們介紹一下php版本的非緩衝查詢json
意思便是 把數據一行行 讀取到php運行內存,並不是一次性讀取到php運行內存,衆所周知,php有不少內置函數,能夠幫助咱們對數據進行加工操做,由於數據都在內存裏面,因此能操做,可是php的運行內存是有極限,默認128M。api
注意:由於非緩衝查詢是 會長時間鏈接數據庫的,有可能會形成慢查詢、鎖表之類的狀況,比較耗mysql資源數組
相對非緩衝查詢就是 緩衝查詢:
若是用緩存查詢,php內存就會直接爆了,出現內存不足的狀況。好了,這裏主要是爲了突出yield
緩存
yield性能函數
生成器會對PHP應用的性能有很是大的影響性能
PHP代碼運行時節省大量的內存
比較適合計算大量的數據
yield運用
生成器容許你在 foreach 代碼塊中寫代碼來迭代一組數據而不須要在內存中建立一個數組,那會使你的內存達到上限,或者會佔據可觀的處理時間。相反,你能夠寫一個生成器函數,就像一個普通的自定義函數同樣, 和普通函數只返回一次不一樣的是, 生成器能夠根據須要 yield 屢次,以便生成須要迭代的值。
例子講解
public function read_temp_api_order_info($number){
for($i=1; $i <= $number; $i++){
$temp_api_order_info = [
'address' => "這裏是磊豐的測試地址:13號50".$i."室",
'card_no' => "8888888711172157",
'city' => "440300",
'create_id' => 1,
'create_name' => "zhuomaquan333",
'created_at' => "2019-11-11 10:05:36",
'customer_name' => "磊豐",
'customer_phone' => "1008611",
'dealer_id' => "111",
'delivery_id' => 115,
'dispatch_info' => "",
'district' => "440306",
'examine_id' => 1,
'examine_name' => "zhuomaquan333",
'goods' => [203 => 3],
'order_id' => "D201911119000".$i,
'order_status' => "14",
'order_type' => 2,
'province' => "440000",
'remark' => null,
'updated_at' => "",
'ware_id' => "151",
];
yield $temp_api_order_info;
}
}
我這裏只是構建了一個數組來給你們演示,日常你在操做數據庫輸出數據也是同樣的。轉爲array
//倉庫庫存扣除測試
public function cangku_stock()
{
//set_time_limit(0); //表示永久運行,這裏我是測試array的時候用到的
$order_info = $this->read_temp_api_order_info(10); //這裏我就測試了10條數據,效果是看不出來的
foreach($order_info as $temp_api_order_info){
dd($temp_api_order_info); //打印出來看看數據
//處理數據
$api_ware_id = $this->o->getCangkuApiUrl() .'ware/program/addOutWare';
$out_wares = api_request($api_ware_id, $temp_api_order_info);
$temp_out_wares = json_decode($out_wares, true);
if ($temp_out_wares['code'] != 1) {
$msg = (isset($temp_out_wares['msg']) && $temp_out_wares['msg']) ? $temp_out_wares['msg'] : var_export($out_wares, true);
throw new Exception($msg);
}
}
//dd("批量更新成功".date('Y-m-d H:i:s'));
}
能夠看到咱們調用 $order_info = $this->read_temp_api_order_info(10);返回了一個 Generator 對象,這個對象可使用 foreach 迭代,每次迭代,PHP 會要求 Generator 實例計算並提供下一個要迭代的值。生成器的優雅體如今每次產出一個值以後,生成器的內部狀態都會停頓;向生成器請求下一個值時,內部狀態又會恢復。生成器內部的狀態會一直在停頓和恢復之間切換,直到抵達函數定義體的末尾或遇到空的 return 語句爲止。效果以下:
這裏測試大量數據,直接更改$this->read_temp_api_order_info(10);就好,若是是計算數據表數量,那你就要改改這個方法了。本身試着更改一下吧。
這裏我主要給你們講解yield的用法,若是要看插入數據表用了多長時間,本身能夠在數據表增長插入時間的字段,再看看第一條數據插入與最後一條數據插入的時候的對比的。
以上是文章所有內容,有須要學習與經驗交流的友人請加入Swoole交流羣學習與交流的我們一塊兒學習,有問題一塊兒交流,一塊兒進步!前提是你是學技術的。感謝閱讀!