Seekable イテレータです。
例1 基本的な使用法
この例では、SeekableIterator を作成して位置を移動し、無効な位置を扱います。
<?php
class MySeekableIterator implements SeekableIterator {
private $position = 0;
private $array = array(
"first element",
"second element",
"third element",
"fourth element"
);
public function seek($position) {
$this->position = $position;
if (!$this->valid()) {
throw new OutOfBoundsException("invalid seek position ($position)");
}
}
/* Iterator インターフェイスで必要なメソッド群 */
public function __construct() {
$this->position = 0;
}
public function rewind() {
$this->position = 0;
}
public function current() {
return $this->array[$this->position];
}
public function key() {
return $this->position;
}
public function next() {
++$this->position;
}
public function valid() {
return isset($this->array[$this->position]);
}
}
try {
$it = new MySeekableIterator;
echo $it->current(), "\n";
$it->seek(2);
echo $it->current(), "\n";
$it->seek(1);
echo $it->current(), "\n";
$it->seek(10);
} catch (OutOfBoundsException $e) {
echo $e->getMessage();
}
?>
上の例の出力は、 たとえば以下のようになります。
first element third element second element invalid seek position (10)