ホームページ > バックエンド開発 > PHPチュートリアル > PHP SPL標準ライブラリのインターフェースの詳細説明、splinterface_PHPチュートリアル

PHP SPL標準ライブラリのインターフェースの詳細説明、splinterface_PHPチュートリアル

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2016-07-13 09:54:29
オリジナル
1243 人が閲覧しました

PHP SPL標準ライブラリsplinterfaceのインターフェース(Interface)の詳細説明

PHP SPL標準ライブラリには以下の合計6つのインターフェースがあります。

1.可算

2.アウターイテレータ
3.再帰反復子
4.SeekableIterator
5.Splオブザーバー
6.SplSubject

OuterIterator、RecursiveIterator、および SeekableIterator はすべて Iterator クラスを継承します。各インターフェイスの機能と使用法については、以下で詳しく説明します。

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テスト
*/

実際のアプリケーションでは、OuterIterator は非常に便利です。

コードをコピーします コードは次のとおりです: $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 現在の要素の子イテレータを取得します

RecursiveIterator::hasChildren は、現在の要素の下に反復子があるかどうかを判断します

复制代码代码如下:
クラス 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代码
*/

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/997905.html技術記事 PHP SPL标標準库之インターフェース(Interface)详解,splinterface PHP SPL标標準库总共有6个インターフェース,如下: 1.Countable 2.OuterIterator 3.RecursiveIterator 4.SeekableIterator 5.SplOb...
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
PHP 拡張子 intl
から 1970-01-01 08:00:00
0
0
0
phpのデータ取得?
から 1970-01-01 08:00:00
0
0
0
phpを上手に学ぶ方法
から 1970-01-01 08:00:00
0
0
0
PHP GET エラー レポート
から 1970-01-01 08:00:00
0
0
0
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート