什么是注册器模式【全局共享和交换对象】
注册树模式当然也叫注册模式,注册器模式。注册树模式通过将对象实例注册到一棵全局的对象树上,需要的时候从对象树上采摘的模式设计方法。
为什么要采用注册树模式?
单例模式解决的是如何在整个项目中创建唯一对象实例的问题,工厂模式解决的是如何不通过new建立实例对象的方法。 那么注册树模式想解决什么问题呢? 在考虑这个问题前,我们还是有必要考虑下前两种模式目前面临的局限。 首先,单例模式创建唯一对象的过程本身还有一种判断,即判断对象是否存在。存在则返回对象,不存在则创建对象并返回。 每次创建实例对象都要存在这么一层判断。 工厂模式更多考虑的是扩展维护的问题。 总的来说,单例模式和工厂模式可以产生更加合理的对象。怎么方便调用这些对象呢?而且在项目内如此建立的对象好像散兵游勇一样,不便统筹管理安排啊。因而,注册树模式应运而生。不管你是通过单例模式还是工厂模式还是二者结合生成的对象,都统统给我“插到”注册树上。我用某个对象的时候,直接从注册树上取一下就好。这和我们使用全局变量一样的方便实用。 而且注册树模式还为其他模式提供了一种非常好的想法。
如何实现注册树?
通过上述的描述,我们似乎很容易就找到了解决方法。首先我们需要一个作为注册树的类,这毋庸置疑。所有的对象“插入”到注册树上。这个注册树应该由一个静态变量来充当。而且这个注册树应该是一个二维数组。这个类应该有一个插入对象实例的方法(set()),当让相对应的就应该有一个撤销对象实例的方法(_unset())。当然最重要的是还需要有一个读取对象的方法(get())。拥有这些,我们就可以愉快地完成注册树模式啦~~~
代码示例
<?php
/**
* 注册树类
*/
class Register
{
protected static $object;
private static $instance;
//单例模式
public static function instance()
{
if (!isset(self::$instance)) {
self::$instance = new self();
}
return self::$instance;
}
//把对象写入成员变量中
public function set($alias, $object)
{
Register::$object[$alias] = $object;
}
//获取指定别名的对象
public function get($name)
{
return Register::$object[$name];
}
//移除指定别名对象
public function _unset($name)
{
unset(Register::$object[$name]);
}
}
/**
* Db类
*/
class Db
{
protected $connect;
public function __construct($host, $username, $password, $dbname)
{
$connect = mysqli_connect($host, $username, $password, $dbname);
$this->connect = $connect;
}
function query($sql)
{
return '查询的SQL语句:' . $sql;
}
function close()
{
mysqli_close($this->connect);
}
}
$db = new Db('127.0.0.1', 'tudou', '123456', 'tudou'); //实例化Db类型
Register::instance()->set('db', $db); //写入到注册树上
$result = Register::instance()->get('db')->query('show database;'); //从注册树上获取Db类并调用查询方法
echo $result;
运行结果:
查询的SQL语句:show database;
代码分析:
首先我们把Db类注册到全局树上,然后通过注册树类的get()方法获取到Db类对象,并执行Db类对象中的query()查询方法。
参考的博客链接:https://www.cnblogs.com/zhangzhijian/p/12305529.html
本文为够意思原创文章,转载无需和我联系,但请注明来自够意思博客blog.go1s.cn:够意思博客 » 设计模式之注册树模式