Class BufferedIterator
Creates an iterator from another iterator that will keep the results of the inner iterator in memory, so that results don't have to be re-calculated.
- IteratorIterator implements Iterator, Traversable, OuterIterator
- Cake\Collection\Collection implements Cake\Collection\CollectionInterface, Serializable uses Cake\Collection\CollectionTrait
- Cake\Collection\Iterator\BufferedIterator implements Countable, Serializable
Properties summary
-
$_buffer
protectedThe in-memory cache containing results from previous iteratorsSplDoublyLinkedList
-
$_current
protectedLast record fetched from the inner iteratormixed
-
$_finished
protectedWhether or not the internal iterator has reached its end.boolean
-
$_index
protectedPoints to the next record number that should be fetchedinteger
-
$_key
protectedLast key obtained from the inner iteratormixed
-
$_started
protectedboolean
Whether or not the internal iterator's rewind method was already called
Method Summary
- __construct() public
Maintains an in-memory cache of the results yielded by the internal iterator.
- count() publicReturns the number or items in this collection
- current() publicReturns the current record in the iterator
- key() publicReturns the current key in the iterator
- next() publicAdvances the iterator pointer to the next element
- rewind() publicRewinds the collection
- serialize() public
Returns a string representation of this object that can be used to reconstruct it
- unserialize() publicUnserializes the passed string and rebuilds the BufferedIterator instance
- valid() publicReturns whether or not the iterator has more elements
Method Detail
__construct()source public
__construct( array|Traversable $items )
Maintains an in-memory cache of the results yielded by the internal iterator.
Parameters
- array|Traversable
$items
- The items to be filtered.
Throws
InvalidArgumentExceptionIf passed incorrect type for items.
Overrides
Cake\Collection\Collection::__construct()
count()source public
count( )
Returns the number or items in this collection
Returns
integerOverrides
Cake\Collection\Collection::count()
Implementation of
Countable::count()
current()source public
current( )
Returns the current record in the iterator
Returns
mixedOverrides
IteratorIterator::current()
key()source public
key( )
Returns the current key in the iterator
Returns
mixedOverrides
IteratorIterator::key()
next()source public
next( )
Advances the iterator pointer to the next element
Overrides
IteratorIterator::next()
serialize()source public
serialize( )
Returns a string representation of this object that can be used to reconstruct it
Returns
stringOverrides
Cake\Collection\Collection::serialize()
Implementation of
Serializable::serialize()
unserialize()source public
unserialize( string $buffer )
Unserializes the passed string and rebuilds the BufferedIterator instance
Parameters
- string
$buffer
- The serialized buffer iterator
Overrides
Cake\Collection\Collection::unserialize()
Implementation of
Serializable::unserialize()
valid()source public
valid( )
Returns whether or not the iterator has more elements
Returns
booleanOverrides
IteratorIterator::valid()
Methods inherited from Cake\Collection\Collection
__debugInfo()source public
__debugInfo( )
Returns an array that can be used to describe the internal state of this object.
Returns
arraycountKeys()source public
countKeys( )
Returns the number of unique keys in this iterator. This is, the number of elements the collection will contain after calling toArray()
Returns
integerImplementation of
Cake\Collection\CollectionInterface::countKeys()
Methods used from Cake\Collection\CollectionTrait
_unwrap()source public
_unwrap( )
append()source public
append( $items )
appendItem()source public
appendItem( $item , $key = null )
avg()source public
avg( $matcher = null )
cartesianProduct()source public
cartesianProduct( callable $operation = null , callable $filter = null )
Parameters
- callable
$operation
optional null - Operation
- callable
$filter
optional null - Filter
Returns
Cake\Collection\CollectionInterface
Throws
LogicExceptionchunk()source public
chunk( $chunkSize )
chunkWithKeys()source public
chunkWithKeys( $chunkSize , $preserveKeys = true )
combine()source public
combine( $keyPath , $valuePath , $groupPath = null )
compile()source public
compile( $preserveKeys = true )
contains()source public
contains( $value )
countBy()source public
countBy( $callback )
each()source public
each( callable $c )
every()source public
every( callable $c )
extract()source public
extract( $matcher )
first()source public
first( )
firstMatch()source public
firstMatch( array $conditions )
groupBy()source public
groupBy( $callback )
indexBy()source public
indexBy( $callback )
isEmpty()source public
isEmpty( )
jsonSerialize()source public
jsonSerialize( )
last()source public
last( )
lazy()source public
lazy( )
listNested()source public
listNested( $dir = 'desc' , $nestingKey = 'children' )
Returns
Cake\Collection\Iterator\TreeIterator
match()source public
match( array $conditions )
max()source public
max( $callback , $type = \SORT_NUMERIC )
median()source public
median( $matcher = null )
min()source public
min( $callback , $type = \SORT_NUMERIC )
nest()source public
nest( $idPath , $parentPath , $nestingKey = 'children' )
optimizeUnwrap()source protected
optimizeUnwrap( )
Unwraps this iterator and returns the simplest traversable that can be used for getting the data out
Returns
Traversable|arrayprepend()source public
prepend( $items )
prependItem()source public
prependItem( $item , $key = null )
reduce()source public
reduce( callable $c , $zero = null )
sample()source public
sample( $size = 10 )
shuffle()source public
shuffle( )
skip()source public
skip( $howMany )
some()source public
some( callable $c )
sortBy()source public
sortBy( $callback , $dir = \SORT_DESC , $type = \SORT_NUMERIC )
sumOf()source public
sumOf( $matcher = null )
take()source public
take( $size = 1 , $from = 0 )
takeLast()source public
takeLast( $howMany )
through()source public
through( callable $handler )
toArray()source public
toArray( $preserveKeys = true )
toList()source public
toList( )
transpose()source public
transpose( )
Returns
Cake\Collection\CollectionInterface
Throws
LogicExceptionunfold()source public
unfold( callable $transformer = null )
unwrap()source public
unwrap( )
zip()source public
zip( $items )
zipWith()source public
zipWith( $items , $callable )
Magic methods inherited from Cake\Collection\CollectionInterface
cartesianProduct() |
Properties detail
$_buffersource
protected SplDoublyLinkedList
The in-memory cache containing results from previous iterators
$_startedsource
protected boolean
Whether or not the internal iterator's rewind method was already called
false
© 2005–present The Cake Software Foundation, Inc.
Licensed under the MIT License.
CakePHP is a registered trademark of Cake Software Foundation, Inc.
We are not endorsed by or affiliated with CakePHP.
https://api.cakephp.org/3.7/class-Cake.Collection.Iterator.BufferedIterator.html