找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 947|回复: 0
打印 上一主题 下一主题

PHP中预定义的6种接口介绍

[复制链接]

3444

主题

3465

帖子

1万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
11142
跳转到指定楼层
楼主
发表于 2018-2-14 05:46:13 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            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 = "ublic property one" ;
  public $property2 = "ublic property two" ;
  public $property3 = "ublic 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" ;
            
            
您可能感兴趣的文章:
  • C#使用IHttpModule接口修改http输出的方法
  • PHP生成json和xml类型接口数据格式
  • C#中实现判断某个类是否实现了某个接口
  • C#中类与接口的区别个人总结
  • C#中的ICustomFormatter及IFormatProvider接口用法揭秘
  • C#显式地实现接口成员的方法
  • 通过C#实现自动售货机接口
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端