PHP Interator接口的作用是允许对象以自己的方式迭代内部的数据,从而使它可以被循环访问
当执行valid返回false时,循环就此结束。
iterator 接口的定义
Iterator extends Traversable {
//返回当前索引游标指向的元素
abstract public mixed current ( void )
//返回当前索引游标指向的键
abstract public scalar key ( void )
//移动当前索引游标到下一元素
abstract public void next ( void )
//重置索引游标
abstract public void rewind ( void )
//判断当前索引游标指向的元素是否有效
abstract public boolean valid ( void )}
示例:
<?php
/**
* 该类允许外部迭代自己内部私有属性$_test,并演示迭代过程
*
* @author 疯狂老司机
*/
class TestIterator implements Iterator {/*
* 定义要进行迭代的数组
*/
private $_test = array(‘dog’, ‘cat’, ‘pig’);/*
* 索引游标
*/
private $_key = 0;/*
* 执行步骤
*/
private $_step = 0;/**
* 将索引游标指向初始位置
*
* @see TestIterator::rewind()
*/
public function rewind() {
echo ‘第’.++$this->_step.’步:执行 ‘.__METHOD__.'<br>’;
$this->_key = 0;
}/**
* 判断当前索引游标指向的元素是否设置
*
* @see TestIterator::valid()
* @return bool
*/
public function valid() {
echo ‘第’.++$this->_step.’步:执行 ‘.__METHOD__.'<br>’;
return isset($this->_test[$this->_key]);
}/**
* 将当前索引指向下一位置
*
* @see TestIterator::next()
*/
public function next() {
echo ‘第’.++$this->_step.’步:执行 ‘.__METHOD__.'<br>’;
$this->_key++;
}
/**
* 返回当前索引游标指向的元素的值
*
* @see TestIterator::current()
* @return value
*/
public function current() {
echo ‘第’.++$this->_step.’步:执行 ‘.__METHOD__.'<br>’;
return $this->_test[$this->_key];
}/**
* 返回当前索引值
*
* @return key
* @see TestIterator::key()
*/
public function key() {
echo ‘第’.++$this->_step.’步:执行 ‘.__METHOD__.'<br>’;
return $this->_key;
}
}$iterator = new TestIterator();
foreach($iterator as $key => $value){
echo “输出索引为{$key}的元素”.”:$value”.'<br><br>’;
}
输出结果:
以上例子将输出:
第1步:执行 TestIterator::rewind
第2步:执行 TestIterator::valid
第3步:执行 TestIterator::current
第4步:执行 TestIterator::key
输出索引为0的元素:dog第5步:执行 TestIterator::next
第6步:执行 TestIterator::valid
第7步:执行 TestIterator::current
第8步:执行 TestIterator::key
输出索引为1的元素:cat第9步:执行 TestIterator::next
第10步:执行 TestIterator::valid
第11步:执行 TestIterator::current
第12步:执行 TestIterator::key
输出索引为2的元素:pig第13步:执行 TestIterator::next
第14步:执行 TestIterator::valid从以上例子可以看出,如果执行valid返回false,则循环就此结束。