2024 年 PHP Conference Japan

iterator_count

(PHP 5 >= 5.1.0, PHP 7, PHP 8)

iterator_count計算迭代器中的元素數量

說明

iterator_count(Traversable|陣列 $iterator): 整數

計算迭代器中的元素數量。 iterator_count() 不保證會保留 iterator 的目前位置。

參數

iterator

要計算的迭代器。

回傳值

iterator 中的元素數量。

更新日誌

版本 說明
8.2.0 iterator 的類型已從 Traversable 擴展到 Traversable|array

範例

範例 #1 iterator_count() 範例

<?php
$iterator
= new ArrayIterator(array('recipe'=>'pancakes', 'egg', 'milk', 'flour'));
var_dump(iterator_count($iterator));
?>

以上範例的輸出

int(4)

範例 #2 iterator_count() 修改位置

<?php
$iterator
= new ArrayIterator(['one', 'two', 'three']);
var_dump($iterator->current());
var_dump(iterator_count($iterator));
var_dump($iterator->current());
?>

以上範例的輸出

string(3) "one"
int(3)
NULL

範例 #3 在 foreach 迴圈中使用 iterator_count()

<?php
$iterator
= new ArrayIterator(['one', 'two', 'three']);
foreach (
$iterator as $key => $value) {
echo
"$key: $value (", iterator_count($iterator), ")\n";
}
?>

以上範例的輸出

0: one (3)

新增筆記

使用者貢獻的筆記 2 則筆記

oleksii dot bulba at gmail dot com
3 年前
請注意,對 NoRewindIterator 進行計數將使項目無法使用

<?php

$iterator
= new ArrayIterator(['recipe'=>'pancakes', 'egg', 'milk', 'flour']);
$iterator = new NoRewindIterator($iterator);

var_dump($iterator->current());
var_dump(iterator_count($iterator));
var_dump($iterator->current());
$iterator->rewind(); // 無法作用,因為它是 NoRewindIterator
var_dump($iterator->current());
var_dump(iterator_count($iterator));

?>

輸出

<?php

/*
string(8) "pancakes"
int(4)
NULL
NULL
*/
int(0)

?>
info at ensostudio dot ru
4 年前
安全使用方式
<?php
$cnt
= iterator_count(clone $iterator);
?>
To Top