この記事では主に、PHP の 6 つの定義済みインターフェイスについて説明します。必要な方は、Traversable、Iterator、IteratorAggregate、ArrayAccess、Serializable、Closure について説明します。
PHP の定義済みインターフェイス 6 つ。インターフェイスは次のように紹介されます。
1.Traversable トラバーサル インターフェイス
ハッ!実際、これは PHP で使用できるインターフェースではなく、内部クラスのみが使用できます。その目的の 1 つは、クラスを横断できるかどうかを検出することです。
if($class instanceof Traversable) { //foreach }
2.Iterator イテレータ インターフェイス
インターフェイスの概要:
Iterator extends Traversable { //返回当前索引游标指向的元素 abstract public mixed current(void) //返回当前索引游标指向的元素的键名 abstract public scalar key(void) //移动当前索引游标指向下一元素 abstract public void next(void) //重置索引游标的指向第一个元素 abstract public void rewind(void) //判断当前索引游标指向的是否是一个元素,常常在调用 rewind()或 next()使用 abstract public boolean valid(void) }
上記により、クラスで基本的な反復関数を実装できるようになります。反復呼び出しシーケンスは次のようになります。
class myIterator implements Iterator { private $position = 0 ; private $array = array( "firstelement" , "secondelement" , "lastelement" , ); public function __construct () { $this -> position = 0 ; } function rewind () { var_dump ( __METHOD__ ); $this -> position = 0 ; } function current () { var_dump ( __METHOD__ ); return $this -> array [ $this -> position ]; } function key () { var_dump ( __METHOD__ ); return $this -> position ; } function next () { var_dump ( __METHOD__ ); ++ $this -> position ; } function valid () { var_dump ( __METHOD__ ); return isset( $this -> array [ $this -> position ]); } } $it = new myIterator ; foreach( $it as $key => $value ) { var_dump ( $key , $value ); echo "\n" ; }
3.IteratorAggregate 集約イテレータ インターフェイス
インターフェイスの概要:
IteratorAggregate extends Traversable { //获取外部迭代器 abstract public Traversable getIterator ( void ) }
getIterator は、Iterator または Traversable インターフェイスのクラスのインスタンスです。反復アクセスを実装するには、次のように外部反復子を取得します。
class myData implements IteratorAggregate { public $property1 = "Public property one" ; public $property2 = "Public property two" ; public $property3 = "Public property three" ; public function __construct () { $this -> property4 = "last property" ; } public function getIterator () { return new ArrayIterator ( $this ); } } $obj = new myData ; foreach( $obj as $key => $value ) { var_dump ( $key , $value ); echo "\n" ; }
4.ArrayAccess 配列アクセス インターフェイス
インターフェイスの概要:
ArrayAccess { /* 方法 */ abstract public boolean offsetExists ( mixed $offset ) //检查偏移位置是否存在 abstract public mixed offsetGet ( mixed $offset ) //获取一个偏移位置的值 abstract public void offsetSet ( mixed $offset , mixed $value ) //设置一个偏移位置的值 abstract public void offsetUnset ( mixed $offset ) //复位一个偏移位置的值 }
オブジェクトは次のように配列のようにアクセスできます:
class obj implements arrayaccess { private $container = array(); public function __construct () { $this -> container = array( "one" => 1 , "two" => 2 , "three" => 3 , ); } public function offsetSet ( $offset , $value ) { if ( is_null ( $offset )) { $this -> container [] = $value ; } else { $this -> container [ $offset ] = $value ; } } public function offsetExists ( $offset ) { return isset( $this -> container [ $offset ]); } public function offsetUnset ( $offset ) { unset( $this -> container [ $offset ]); } public function offsetGet ( $offset ) { return isset( $this -> container [ $offset ]) ? $this -> container [ $offset ] : null ; } } $obj = new obj ; var_dump (isset( $obj [ "two" ])); var_dump ( $obj [ "two" ]); unset( $obj [ "two" ]); var_dump (isset( $obj [ "two" ])); $obj [ "two" ] = "A value" ; var_dump ( $obj [ "two" ]); $obj [] = 'Append 1' ; $obj [] = 'Append 2' ; $obj [] = 'Append 3' ; print_r ( $obj );
5 .直列化可能なシリアル化インターフェイス
インターフェイスの概要:
Serializable { /* 方法 */ abstract public string serialize ( void ) //对象的字符串表示 abstract public mixed unserialize ( string $serialized ) // 构造对象 }
このインターフェイスを実装するクラスは、__sleep() および __wakeup() をサポートしなくなりました。使い方は非常に簡単で、オブジェクトをシリアル化するときにserializeメソッドを呼び出し、逆シリアル化するときにunserializeメソッドを呼び出すだけです。
class obj implements Serializable { private $data ; public function __construct () { $this -> data = "My private data" ; } public function serialize () { return serialize ( $this -> data ); } public function unserialize ( $data ) { $this -> data = unserialize ( $data ); } public function getData () { return $this -> data ; } } $obj = new obj ; $ser = serialize ( $obj ); print_r($ser); $newobj = unserialize ( $ser ); print_r($newobj);
6.Closure
インターフェイスの概要:
Closure { /* 方法 */ __construct ( void ) //用于禁止实例化的构造函数 public static Closure bind ( Closure $closure , object $newthis [, mixed $newscope = 'static' ] ) //复制一个闭包,绑定指定的$this对象和类作用域。 public Closure bindTo ( object $newthis [, mixed $newscope = 'static' ] ) //复制当前闭包对象,绑定指定的$this对象和类作用域。 }
class A { private static $sfoo = 1 ; private $ifoo = 2 ; } $cl1 = static function() { return A :: $sfoo ; }; $cl2 = function() { return $this -> ifoo ; }; $bcl1 = Closure :: bind ( $cl1 , null , 'A' ); $bcl2 = Closure :: bind ( $cl2 , new A (), 'A' ); echo $bcl1 (), "\n" ; echo $bcl2 (), "\n" ;
概要: 上記がこの記事の全内容です。皆様の学習に役立つことを願っています。 。
関連する推奨事項:
PHP 配列を Apple plist XML に変換するまたはテキスト形式関数
phpは中国のプロキシサーバーネットワークの収集を実現します
以上がPHP の 6 つの定義済みインターフェイスの紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。