php预定义了6个接口介绍如下:
1.traversable遍历接口
呵呵!其实它不是一个在php中可以使用的接口,内部类才可使用,它有一个用途就是检测一个类是否可以遍历。
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序列化接口
接口摘要:
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 ;