官方解釋yield
龍崗網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)公司等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營維護(hù)。創(chuàng)新互聯(lián)于2013年成立到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。
yield生成器
是php5.5
之后出現(xiàn)的,官方文檔這樣解釋:yield
提供了一種更容易的方法來實(shí)現(xiàn)簡單的迭代對象,相比較定義類實(shí)現(xiàn) Iterator
接口的方式,性能開銷和復(fù)雜性大大降低。
生成器的核心是一個(gè)yield
關(guān)鍵字,一個(gè)生成器函數(shù)看起來像一個(gè)普通的函數(shù),不同的是:普通函數(shù)返回一個(gè)值,而一個(gè)生成器可以yield
生成許多它所需要的值。生成器函數(shù)被調(diào)用時(shí),返回的是一個(gè)可以被遍歷的對象。
yield
和return
有點(diǎn)類似,不過不同的是,return
會(huì)返回值并且終止代碼的執(zhí)行,而yield
會(huì)返回一個(gè)值給循環(huán)調(diào)用此生成器的代碼并且只是暫停執(zhí)行生成器函數(shù)。
這里順便給大家介紹一下php版本的非緩沖查詢
意思即是 把數(shù)據(jù)一行行 讀取到php運(yùn)行內(nèi)存,并非一次性讀取到php運(yùn)行內(nèi)存,眾所周知,php有很多內(nèi)置函數(shù),可以幫助我們對數(shù)據(jù)進(jìn)行加工操作,因?yàn)閿?shù)據(jù)都在內(nèi)存里面,所以能操作,但是php的運(yùn)行內(nèi)存是有極限,默認(rèn)128M。
注意:因?yàn)榉蔷彌_查詢是 會(huì)長時(shí)間連接數(shù)據(jù)庫的,有可能會(huì)造成慢查詢、鎖表之類的情況,比較耗MySQL資源
相對非緩沖查詢就是 緩沖查詢:
如果用緩存查詢,php內(nèi)存就會(huì)直接爆了,出現(xiàn)內(nèi)存不足的情況。好了,這里主要是為了突出yield
yield性能
生成器會(huì)對PHP應(yīng)用的性能有非常大的影響
PHP代碼運(yùn)行時(shí)節(jié)省大量的內(nèi)存
比較適合計(jì)算大量的數(shù)據(jù)
yield運(yùn)用
生成器允許你在 foreach 代碼塊中寫代碼來迭代一組數(shù)據(jù)而不需要在內(nèi)存中創(chuàng)建一個(gè)數(shù)組,那會(huì)使你的內(nèi)存達(dá)到上限,或者會(huì)占據(jù)可觀的處理時(shí)間。相反,你可以寫一個(gè)生成器函數(shù),就像一個(gè)普通的自定義函數(shù)一樣, 和普通函數(shù)只返回一次不同的是, 生成器可以根據(jù)需要 yield 多次,以便生成需要迭代的值。
例子講解
我這里只是構(gòu)建了一個(gè)數(shù)組來給大家演示,平常你在操作數(shù)據(jù)庫輸出數(shù)據(jù)也是一樣的。轉(zhuǎn)為array
//倉庫庫存扣除測試 public function cangku_stock() { //set_time_limit(0); //表示永久運(yùn)行,這里我是測試array的時(shí)候用到的 $order_info = $this->read_temp_api_order_info(10); //這里我就測試了10條數(shù)據(jù),效果是看不出來的 foreach($order_info as $temp_api_order_info){ dd($temp_api_order_info); //打印出來看看數(shù)據(jù) //處理數(shù)據(jù) $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'));
可以看到我們調(diào)用 $order_info = $this->read_temp_api_order_info(10);返回了一個(gè) Generator 對象,這個(gè)對象可以使用 foreach 迭代,每次迭代,PHP 會(huì)要求 Generator 實(shí)例計(jì)算并提供下一個(gè)要迭代的值。
生成器的優(yōu)雅體現(xiàn)在每次產(chǎn)出一個(gè)值之后,生成器的內(nèi)部狀態(tài)都會(huì)停頓;向生成器請求下一個(gè)值時(shí),內(nèi)部狀態(tài)又會(huì)恢復(fù)。生成器內(nèi)部的狀態(tài)會(huì)一直在停頓和恢復(fù)之間切換,直到抵達(dá)函數(shù)定義體的末尾或遇到空的 return 語句為止。
效果如下:
這里測試大量數(shù)據(jù),直接更改$this->read_temp_api_order_info(10);就
好,如果是計(jì)算數(shù)據(jù)表數(shù)量,那你就要改改這個(gè)方法了。自己試著更改一下吧。
這里我主要給大家講解yield的用法,如果要看插入數(shù)據(jù)表用了多長時(shí)間,自己可以在數(shù)據(jù)表增加插入時(shí)間的字段,再看看第一條數(shù)據(jù)插入與最后一條數(shù)據(jù)插入的時(shí)候的對比的。
以上就是PHP生成器yield處理大量數(shù)據(jù)業(yè)務(wù)(代碼示例)的詳細(xì)內(nèi)容,更多請關(guān)注創(chuàng)新互聯(lián)其它相關(guān)文章!