Rumah  >  Artikel  >  pembangunan bahagian belakang  >  代码详解php中的ArrayAccess接口

代码详解php中的ArrayAccess接口

伊谢尔伦
伊谢尔伦asal
2017-06-29 09:47:261561semak imbas

slim中的依赖注入基于pimple,于是又去学习了一下pimple。 对比之前自己写的依赖注入类,pimple有一个很新鲜的用法,不是采用

$container->session_storage = function ($c) {
    return new $c['session_storage_class']($c['cookie_name']);
};

而是以数组方式进行注入:

$container['session_storage'] = function ($c) {
    return new $c['session_storage_class']($c['cookie_name']);
};

看源码时才发现原来诀窍就在php5提供的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 ) #删除数据

如果想让对象使用起来像一个 PHP 数组,那么我们需要实现 ArrayAccess 接口

代码如下:

interface ArrayAccess 
boolean offsetExists($index) 
mixed offsetGet($index) 
void offsetSet($index, $newvalue) 
void offsetUnset($index)


下面的例子展示了如何使用这个接口,例子并不是完整的,但是足够看懂,:->

 代码如下:

<?php 
class UserToSocialSecurity implements ArrayAccess 
{ 
private $db;//一个包含着数据库访问方法的对象 
function offsetExists($name) 
{ 
return
 $this->db->userExists($name); 
} 
function offsetGet($name) 
{ 
return $this->db->getUserId($name); 
} 
function offsetSet($name, $id) 
{ 
$this->db->setUserId($name, $id); 
} 
function offsetUnset($name) 
{ 
$this->db->removeUser($name); 
} 
} 
$userMap = new UserToSocialSecurity(); 
print "John&#39;s ID number is " . $userMap[&#39;John&#39;]; 
?>


实际上,当 $userMap['John'] 查找被执行时,PHP 调用了 offsetGet() 方法,由这个方法再来调用数据库相关的 getUserId() 方法。

Atas ialah kandungan terperinci 代码详解php中的ArrayAccess接口. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn