PHP SPL標準ライブラリのインターフェースを詳しく解説_PHPチュートリアル
PHP SPL標準ライブラリのインターフェース(Interface)の詳細説明
この記事では、PHP SPL標準ライブラリのインターフェース(Interface)の詳細説明を中心に紹介します この記事では、Coutableインターフェース、OuterIteratorインターフェース、RecursiveIteratorについて解説します。インターフェイス、SeekableIterator インターフェイス、SplObserver および SplSubject インターフェイス、その他のコンテンツは、必要な友人が参照できます
PHP SPL標準ライブラリには、以下の合計6つのインターフェースがあります。
1.可算2.OuterIterator
3.RecursiveIterator
4.SeekableIterator
5.SplObserver
6.SplSubject
このうち、OuterIterator、RecursiveIterator、SeekableIteratorはいずれもIteratorクラスを継承しています。各インターフェースの機能と使い方については、以下で詳しく説明します。
Coutableインターフェース:
Countableインターフェースを実装したオブジェクトは、count()関数によるカウントに使用できます。
コードは次のとおりです:
クラス Mycount は Countable を実装します
{
パブリック関数 count()
{
静的 $count = 0;
$count++;
$count を返す;
}
}
$count = new Mycount();
$count->count();
$count->count();
エコーカウント($count); //3
エコーカウント($count); //4
説明:
count() 関数を呼び出すと、Mycount::count() メソッドが呼び出されます
count()関数の2番目のパラメータは効果がありません
OuterIteratorインターフェース:
反復プロセスをカスタマイズまたは変更します。
コードは以下の通りです:
//IteratorIteratorはOuterIteratorの実装クラスです
class MyOuterIterator extends IteratorIterator {
パブリック関数 current()
{
returnparent::current() 'TEST';
}
}
foreach(new MyOuterIterator(new ArrayIterator(['b','a','c'])) as $key => $value) {
echo "$key->$value".PHP_EOL;
}
/*
結果:
0->bTEST
1->テスト
2->cTEST
*/
実際のアプリケーションでは、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;
}
公開関数キー() {
return $this->_position;
}
}
$arr = array(0, 1=> array(10, 20), 2, 3 => array(1, 2));
$mri = new MyRecursiveIterator($arr);
foreach ($mri as $c => $v) {
if ($mri->hasChildren()) {
echo "$c には子があります: " .PHP_EOL;
$mri->getChildren();
} 他 {
エコー "$v" .PHP_EOL;
}
}
/*
結果:
0
1人には子供がいます:
配列
(
[0] => 10
[1] => 20
)
2
3人には子供がいます:
配列
(
[0] => 1
[1] => 2
)
*/
SeekableIteratorインターフェース:
特定の位置にある要素を検索するために使用される、seek() メソッドを通じて検索可能なイテレータを実装します。
コードは以下の通りです:
クラス MySeekableIterator は SeekableIterator を実装します {
private $position = 0;
private $array = array(
「最初の要素」、
「第二要素」、
「第三要素」、
「第四の要素」
);
public function seen ( $position ) {
if (!isset( $this -> array [ $position ])) {
throw new OutOfBoundsException ( "無効なシーク位置 ( $position )" );
}
$this ->位置 = $位置 ;
}
public function rewind() {
$this ->位置 = 0 ;
}
public function current () {
$this を返す ->配列 [ $this ->位置];
}
公開ファンクションキー() {
$this を返す ->位置 ;
}
public function next () {
++ $this ->位置 ;
}
パブリック関数有効() {
return isset( $this ->gt; array [ $this ->position ]);
}
}
試してみましょう
$it = 新しい MySeekableIterator ;
echo $it ->現在の ()、「n」 ;
$it ->シーク ( 2 );
echo $it ->現在の ()、「n」 ;
$it ->シーク ( 1 );
echo $it ->現在の ()、「n」 ;
$it ->シーク ( 10 );
} catch ( OutOfBoundsException $e ) {
echo $e -> getMessage();
}
/*
結果:
最初の要素
第三要素
2番目の要素
無効なシーク位置 ( 10 )
*/
SplObserver と SplSubject インターフェース:
SplObserver と SplSubject インターフェイスは、ビューワ設定モードを実現するために使用されます。ビューワ設定モードとは、ある種類の状態が変化したときに、そのオブジェクトが通知を受けて更新されることを意味します。イベント発生その後、複数の更新操作が必要になります。転送方式では、イベントの追加後にこのコードが結合され、保存され、ビューアモードで低結合の通知および更新機構が実現されます。
SplObserver と SplSubject のインターフェース構造:代幣如下:
//SplSubject结构被観察オブジェクト
インターフェース SplSubject{
public functionattach(SplObserver $observer); //観察者追加
public function detach(SplObserver $observer); //剔除观観察者
パブリック関数notify(); // 通知観察者
}
//SplObserver结构代表観察者
インターフェースSplObserver{
public function update(SplSubject $subject); //操作を更新します
}
次の観察者の例:
复制代码代码如下:
クラス Subject は SplSubject を実装します
{
private $observers = array();
パブリック関数attach(SplObserver $observer)
{
$this->observers[] = $observer;
}
public function 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を実装します
{
public function update(SplSubject $subject)
{
echo "逻辑1代码".PHP_EOL;
}
}
クラスObserver2はSplObserverを実装します
{
public function update(SplSubject $subject)
{
echo "逻辑2代码".PHP_EOL;
}
}
$subject = new Subject();
$subject->attach(new Observer1());
$subject->attach(new Observer2());
$subject->notify();
/*
結果:
逻辑1代
逻辑2代
*/
について解説します。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

あなたが経験豊富な PHP 開発者であれば、すでにそこにいて、すでにそれを行っていると感じているかもしれません。あなたは、運用を達成するために、かなりの数のアプリケーションを開発し、数百万行のコードをデバッグし、大量のスクリプトを微調整してきました。

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

このチュートリアルでは、PHPを使用してXMLドキュメントを効率的に処理する方法を示しています。 XML(拡張可能なマークアップ言語)は、人間の読みやすさとマシン解析の両方に合わせて設計された多用途のテキストベースのマークアップ言語です。一般的にデータストレージに使用されます

文字列は、文字、数字、シンボルを含む一連の文字です。このチュートリアルでは、さまざまな方法を使用してPHPの特定の文字列内の母音の数を計算する方法を学びます。英語の母音は、a、e、i、o、u、そしてそれらは大文字または小文字である可能性があります。 母音とは何ですか? 母音は、特定の発音を表すアルファベットのある文字です。大文字と小文字など、英語には5つの母音があります。 a、e、i、o、u 例1 入力:string = "tutorialspoint" 出力:6 説明する 文字列「TutorialSpoint」の母音は、u、o、i、a、o、iです。合計で6元があります

静的結合(静的::) PHPで後期静的結合(LSB)を実装し、クラスを定義するのではなく、静的コンテキストで呼び出しクラスを参照できるようにします。 1)解析プロセスは実行時に実行されます。2)継承関係のコールクラスを検索します。3)パフォーマンスオーバーヘッドをもたらす可能性があります。

PHPの魔法の方法は何ですか? PHPの魔法の方法には次のものが含まれます。1。\ _ \ _コンストラクト、オブジェクトの初期化に使用されます。 2。\ _ \ _リソースのクリーンアップに使用される破壊。 3。\ _ \ _呼び出し、存在しないメソッド呼び出しを処理します。 4。\ _ \ _ get、dynamic属性アクセスを実装します。 5。\ _ \ _セット、動的属性設定を実装します。これらの方法は、特定の状況で自動的に呼び出され、コードの柔軟性と効率を向上させます。
