공식설명수율yield
yield生成器
是php5.5
之后出现的,官方文档这样解释:yield
提供了一种更容易的方法来实现简单的迭代对象,相比较定义类实现 Iterator
接口的方式,性能开销和复杂性大大降低。
生成器的核心是一个yield
关键字,一个生成器函数看起来像一个普通的函数,不同的是:普通函数返回一个值,而一个生成器可以yield
生成许多它所需要的值。生成器函数被调用时,返回的是一个可以被遍历的对象。
yield
和return
有点类似,不过不同的是,return
会返回值并且终止代码的执行,而yield
会返回一个值给循环调用此生成器的代码并且只是暂停执行生成器函数。
这里顺便给大家介绍一下php版本的非缓冲查询
意思即是 把数据一行行 读取到php运行内存,并非一次性读取到php运行内存,众所周知,php有很多内置函数,可以帮助我们对数据进行加工操作,因为数据都在内存里面,所以能操作,但是php的运行内存是有极限,默认128M。
注意:因为非缓冲查询是 会长时间连接数据库的,有可能会造成慢查询、锁表之类的情况,比较耗mysql资源
相对非缓冲查询就是 缓冲查询:
如果用缓存查询,php内存就会直接爆了,出现内存不足的情况。好了,这里主要是为了突出yield
yield性能
生成器会对PHP应用的性能有非常大的影响
PHP代码运行时节省大量的内存
比较适合计算大量的数据
yield运用
生成器允许你在 foreach 代码块中写代码来迭代一组数据而不需要在内存中创建一个数组,那会使你的内存达到上限,或者会占据可观的处理时间。相反,你可以写一个生成器函数,就像一个普通的自定义函数一样, 和普通函数只返回一次不同的是, 生成器可以根据需要 yield 多次,以便生成需要迭代的值。
例子讲解
我这里只是构建了一个数组来给大家演示,平常你在操作数据库输出数据也是一样的。转为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 생성기
는 php5.5
이후에 등장했습니다. 공식 문서에서는 다음과 같이 설명합니다. yield
는 간단한 구현 방법을 제공합니다. Iterator
인터페이스를 구현하기 위한 클래스를 사용하면 반복 개체의 성능 오버헤드와 복잡성이 크게 줄어듭니다.
yield
키워드입니다. 생성기 함수는 일반 함수처럼 보입니다. 차이점은 일반 함수는 값을 반환한다는 것입니다. 프로세서는 필요한 만큼의 값을 생성할 수 있습니다. 생성기 함수가 호출되면 반복할 수 있는 객체를 반환합니다.
yield
는 return
과 다소 유사하지만, return
이 값을 반환하고 실행을 종료한다는 차이점이 있습니다. 대신 yield
는 이 생성기를 반복하는 코드에 값을 반환하고 생성기 함수의 실행을 일시 중지합니다.
그런데, 버퍼링되지 않은 쿼리의 PHP 버전을 소개하고 싶습니다 #🎜 🎜#데이터를 한 행에 넣는다는 뜻입니다. 행은 PHP 실행 메모리로 읽히는 것이지, PHP 실행 메모리를 한 번에 읽는 것이 아닙니다. 우리 모두 알고 있듯이 PHP에는 데이터 처리에 도움이 되는 많은 내장 함수가 있습니다. 데이터가 메모리에 있기 때문에 연산이 가능하지만, PHP를 실행하면 메모리에 제한이 있어 기본값은 128M입니다.
#🎜🎜#참고: 버퍼링되지 않은 쿼리는 데이터베이스에 연결하는 데 오랜 시간이 걸리므로 쿼리 속도가 느려지거나 테이블 잠금 등이 발생하여 더 많은 mysql 리소스가 소모될 수 있습니다#🎜🎜##🎜🎜 ##🎜 🎜#상대 비버퍼 쿼리는 버퍼 쿼리입니다: #🎜🎜##🎜🎜##🎜🎜#캐시된 쿼리를 사용하면 PHP 메모리가 직접적으로 폭발하여 메모리가 부족해집니다. 좋아요, 여기서는 주로 수율을 강조하기 위한 것입니다#🎜🎜##🎜🎜##🎜🎜#yield Performance#🎜🎜##🎜🎜##🎜🎜#생성기는 PHP 성능에 적용됩니다 매우 큰 영향을 미칩니다#🎜🎜##🎜🎜#PHP 코드 실행 시 많은 메모리 절약#🎜🎜##🎜🎜#대량의 데이터 계산에 더 적합#🎜🎜##🎜🎜## 🎜🎜#yield #🎜🎜##🎜🎜#Using #🎜🎜##🎜🎜##🎜🎜#생성기를 사용하면 foreach 블록에 코드를 작성하여 메모리에 배열을 만들지 않고도 데이터 집합을 반복할 수 있습니다. 메모리 한도에 도달했거나 상당한 처리 시간이 소요되고 있습니다. 대신 일반 사용자 정의 함수처럼 생성기 함수를 작성할 수 있으며, 한 번만 반환하는 일반 함수 대신 생성기는 반복해야 하는 값을 생성하는 데 필요한 만큼 여러 번 생성할 수 있습니다. #🎜🎜##🎜🎜#설명예#🎜🎜##🎜🎜##🎜🎜##🎜🎜# #🎜🎜##🎜🎜# #🎜🎜##🎜🎜#여기 있어요 방금 여러분에게 보여드리기 위해 배열을 구성했습니다. 일반적으로 데이터베이스를 조작하여 데이터를 출력할 때도 마찬가지입니다. 배열로 변환#🎜🎜#rrreee#🎜🎜#$order_info = $this->read_temp_api_order_info(10);를 호출하고 Generator 객체를 반환하는 것을 볼 수 있습니다. 이 객체는 각 반복마다 PHP를 사용하여 반복될 수 있습니다. Generator 인스턴스가 반복할 다음 값을 계산하고 제공하도록 요청합니다. #🎜🎜##🎜🎜#생성기의 우아함은 값이 생성될 때마다 생성기에서 다음 값이 요청될 때 생성기의 내부 상태가 일시 중지되고 내부 상태가 다음과 같다는 사실에 반영됩니다. 복원되었습니다. 생성기의 내부 상태는 함수 정의 끝에 도달하거나 빈 return 문을 만날 때까지 정지와 재개 사이를 전환합니다. #🎜🎜##🎜🎜#효과는 다음과 같습니다: #🎜🎜##🎜🎜# #🎜🎜##🎜🎜# 여기에서 많은 데이터를 테스트하고$this->read_temp_api_order_info(10);
만 변경하면 됩니다. > 좋습니다. 데이터 테이블 수를 계산하는 것이라면 이 방법을 변경해야 합니다. 직접 바꿔보세요. #🎜🎜##🎜🎜##🎜🎜##🎜🎜##🎜🎜# #🎜🎜##🎜🎜# #🎜🎜##🎜🎜#여기서는 주로 Yield의 사용법을 설명하겠습니다. 삽입을 보고 싶습니다. 데이터 테이블에 걸리는 시간을 확인하려면 데이터 테이블에 삽입 시간 필드를 추가한 다음 첫 번째 데이터 삽입과 마지막 데이터 삽입 간의 비교를 살펴보세요. #🎜🎜##🎜🎜#관련 PHP 지식을 더 보려면 #🎜🎜#php 튜토리얼#🎜🎜#을 방문하세요! #🎜🎜#위 내용은 PHP 생성기 수율은 대량의 데이터 비즈니스를 처리합니다(코드 예)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!