PHP SPL標準ライブラリには以下の合計6つのインターフェースがあります。
1.可算
2.アウターイテレータ
3.再帰反復子
4.SeekableIterator
5.Splオブザーバー
6.SplSubject
Coutableインターフェース:
Countable インターフェースを実装するオブジェクトは、count() 関数でカウントするために使用できます。
コードをコピーします コードは次のとおりです:
Mycount クラスは Countable を実装します
{
パブリック関数 count()
{
静的 $count = 0;
$count++;
return $count;
}
}
$count = 新しい Mycount();
$count->count();
$count->count();
エコー数($count); //3
エコー数($count); //4
count() 関数を呼び出すと、Mycount::count() メソッドが呼び出されます
count() 関数の 2 番目のパラメーターは効果がありません
OuterIterator インターフェイス:
反復プロセスをカスタマイズまたは変更します。
コードをコピーします コードは次のとおりです:
//IteratorIterator は、OuterIterator の実装クラスです
class MyOuterIterator extends IteratorIterator {
パブリック関数 current()
{
'TEST';
を返します。
}
}
foreach(new MyOuterIterator(new ArrayIterator(['b','a','c'])) as $key => $value) {
echo "$key->$value".PHP_EOL;
}
/*
結果:
0->bテスト
1->テスト
2->cテスト
*/
コードをコピーします コードは次のとおりです:
$db = 新しい PDO('mysql:host=localhost;dbname=test', 'root', 'mckee');
$db->query('set names utf8');
$pdoStatement = $db->query('SELECT * FROM test1', PDO::FETCH_ASSOC);
$iterator = new IteratorIterator($pdoStatement);
$tenRecordArray = iterator_to_array($iterator);
print_r($tenRecordArray);
RecursiveIterator インターフェース:
多層構造でデータをループおよび反復するために、RecursiveIterator は 2 つの追加メソッドを提供します。
RecursiveIterator::getChildren 現在の要素の子イテレータを取得します
复制代码代码如下:
クラス MyRecursiveIterator は RecursiveIterator を実装します
{
プライベート $_data;
プライベート $_position = 0;
パブリック関数 __construct(array $data) {
$this->_data = $data;
}
パブリック関数 valid() {
return isset($this->_data[$this->_position]);
}
パブリック関数 hasChildren() {
return is_array($this->_data[$this->_position]);
}
パブリック関数 next() {
$this->_position++;
}
パブリック関数 current() {
return $this->_data[$this->_position];
}
パブリック関数 getChildren() {
print_r($this->_data[$this->_position]);
}
パブリック関数 rewind() {
$this->_position = 0;
}
パブリック関数キー() {
$this->_position;を返す
}
}
$arr = 配列(0, 1=> 配列(10, 20), 2, 3 => 配列(1, 2));
$mri = 新しい MyRecursiveIterator($arr);
foreach ($mri as $c => $v) {
if ($mri->hasChildren()) {
echo "$c には子があります: " .PHP_EOL;
$mri->getChildren();
} その他 {
echo "$v" .PHP_EOL;
}
}
/*
結果:
0
1 人には子供がいます:
配列
(
[0] => 10
[1] => 20
)
2
3人には子供がいます:
配列
(
[0] => 1
[1] => 2
)
*/
SeekableIteratorインターフェース:
特定の位置にある要素を検索するために使用される、seek() メソッドを通じて検索可能なイテレータを実装します。
コードをコピーします コードは次のとおりです:
class MySeekableIterator は SeekableIterator {
を実装します
プライベート $position = 0;
プライベート $array = array(
「最初の要素」 ,
「2番目の要素」、
「第三要素」
「第四の要素」
);
パブリック関数シーク ($position) {
If (!isset( $this -> array [ $position ])) {
throw new OutOfBoundsException ( "無効なシーク位置 ( $position )" );
}
$this -> 位置 = $位置 ;
}
パブリック関数 rewind () {
$this -> 位置 = 0 ;
}
パブリック関数 current () {
$this -> 配列 [ $this -> 位置 ];
を返します。
}
公開ファンクションキー () {
$this -> 位置を返します ;
}
パブリック関数 next () {
++ $this -> 位置 ;
}
パブリック関数有効 () {
return isset( $this ->gt; array [ $this ->position ]);
}
}
試してみてください{
$it = 新しい MySeekableIterator ;
echo $it -> current (), "n" ;
$it -> シーク (2);
echo $it -> current (), "n" ;
$it -> シーク (1);
echo $it -> current (), "n" ;
$it -> シーク ( 10 );
} catch (OutOfBoundsException $e) {
echo $e -> getMessage();
}
/*
結果:
最初の要素
3 番目の要素
2 番目の要素
無効なシーク位置 (10)
*/
SplObserver および SplSubject インターフェイス:
SplObserver インターフェイスと SplSubject インターフェイスは、オブザーバー デザイン パターンを実装するために使用されます。オブザーバー デザイン パターンは、クラスの状態が変化すると、それに依存するオブジェクトが通知され、更新されることを意味します。使用シナリオは非常に多岐にわたります。たとえば、イベントが発生した場合、従来の方法では、イベントが追加された後にロジックを作成する必要があり、保守が困難です。パターンは、低結合の通知および更新メカニズムを実装できます。
SplObserver と SplSubject のインターフェース構造を見てください:
コードをコピーします コードは次のとおりです:
//SplSubject 構造観察オブジェクト
インターフェイス SplSubject{
パブリック関数attach(SplObserver $observer) //オブザーバーを追加します
パブリック関数 detach(SplObserver $observer); // オブザーバーを削除します
パブリック関数 notification() // オブザーバーに通知します
;
}
//SplObserver 構造体はオブザーバーを表します
インターフェース SplObserver{
パブリック関数 update(SplSubject $subject) //更新操作
;
}
次のオブザーバーの実装例を見てください:
复制代码代码如下:
クラス Subject は SplSubject を実装します
{
プライベート $observers = array();
パブリック関数アタッチ(SplObserver $observer)
{
$this->observers[] = $observer;
}
パブリック関数 detach(SplObserver $observer)
{
if($index = array_search($observer, $this->observers, true)) {
unset($this->observers[$index]);
}
}
パブリック関数notify()
{
foreach($this->observers as $observer) {
$observer->update($this);
}
}
}
クラス Observer1 は SplObserver を実装します
{
パブリック関数の更新(SplSubject $subject)
{
echo "逻辑1代码".PHP_EOL;
}
}
クラス Observer2 は SplObserver を実装します
{
パブリック関数の更新(SplSubject $subject)
{
echo "逻辑2代码".PHP_EOL;
}
}
$subject = 新しい Subject();
$subject->attach(new Observer1());
$subject->attach(new Observer2());
$subject->notify();
/*
結果:
逻辑1代码
逻辑2代码
*/