PHP模式设计之单例模式、工厂模式、注册树模式

1.php模式设计之单例模式

  什么是单例模式?

  单例模式是指在整个应用中只有一个实例对象的设计模式

  为什么要用单例模式?

  php经常要链接数据库,如果在一个项目中频繁建立连接数据库,会造成服务器资源的很大浪费,在团队合作项目中,也能够避免不同的程序员实例自己的对象,造成人为的系统消耗。

  单例模式的三大原则

  1.构造函数需要标记为非public(防止外部使用new操作符创建对象),单例类不能在其他类中实例化,只能被其自身实例化

  2.拥有一个保存类的实例的静态成员变量$_instance

  3.拥有一个可以访问这个实例的公共静态方法

<?php
    /**
    * php设计模式之单例模式
    */
    class Db
    {
        static private $_instance;

        final protected function __construct()
        {
            # code...
        }

        public static function getInstance()
        {
            if (!self::$_instance instanceof self) {
                self::$_instance=new Db();
            }
            return self::$_instance;
        }

        public function connect()
        {
            //链接数据库
        }
    }
?>

2. php模式设计之工厂模式

  什么是工厂模式?

  工厂模式是指根据不同的参数生成不同的类实例。

  为什么要用工厂模式?

  减少代码进行复制粘帖,耦合关系重,牵一发动其他部分代码,比如在项目中很多地方实例化某个类,现在突然发现类名不合适或者类中需要添加构造函数参数,难不成需要一个个改?典型的例子就是连接数据库,php中连接数据库有好几种方法,mysql扩展,mysqli扩展等,这个时候就可以用到工厂模式。

<?php
    /**
    * php设计模式之工厂模式
    */
    class Db
    {
        public static function factory($param){
            switch ($param) {
                case 'mysql':
                    return new Class1();
                    break;

                case 'mysqli':
                    return new Class2();
                    break;

                case 'mssql':
                    return new Class3();
                    break;
            }
        }
    }

    interface Connect
    {
        public function fun1($param);
    }

    class Class1 implements Connect
    {
        public function fun1($param){
            //具体实现
        }
    }

    class Class2 implements Connect
    {
        public function fun1($param){
            //具体实现
        }
    }

    class Class3 implements Connect
    {
        public function fun1($param){
            //具体实现
        }
    }
?>

3. php模式设计之注册树模式

  什么是注册树模式?

  注册树模式通过将对象实例注册到全局对象树上,需要的时候将对象从全局对象树上取下来

  为什么要用工厂模式?

  前面讲到的单例模式解决了在整个项目中创建唯一对象的问题工厂模式解决了不通过new解决实例对象的问题,考虑的是项目扩展与维护。总得来说单例模式和工厂模式可以产生更加合理的对象,那么怎么方便统筹调用这些对象呢,这时候就用到了注册树模式,不管你是单例模式,工厂模式还是二者结合生成的对象,都统统给我注册到树上,用某个对象的时候,直接从树上取下来就好

 那么注册树模式想解决什么问题呢? 在考虑这个问题前,我们还是有必要考虑下前两种模式目前面临的局限。  首先,单例模式创建唯一对象的过程本身还有一种判断,即判断对象是否存在。存在则返回对象,不存在则创建对象并返回。 每次创建实例对象都要存在这么一层判断工厂模式更多考虑的是扩展维护的问题。 总的来说,单例模式和工厂模式可以产生更加合理的对象。怎么方便调用这些对象呢?而且在项目内如此建立的对象好像散兵游勇一样,不便统筹管理安排啊。因 而,注册树模式应运而生。不管你是通过单例模式还是工厂模式还是二者结合生成的对象,都统统给我“插到”注册树上。我用某个对象的时候,直接从注册树上取 一下就好。这和我们使用全局变量一样的方便实用。 而且注册树模式还为其他模式提供了一种非常好的想法。

<?php

    /**
    * 单例模式
    */
    class Signal
    {
        static private $_instance;

        final protected function __construct()
        {
            # code...
        }

        public static function getInstance()
        {
            if (!self::$_instance instanceof self) {
                self::$_instance=new Signal();
            }
            return self::$_instance;
        }

        public function connect()
        {
            //链接数据库
        }
    }

    /**
    * 工厂模式
    */
    class Db
    {
        public static function factory($param='')
        {
            switch ($param) {
                case 'mysql':
                    return new Class1();
                    break;

                case 'mysqli':
                    return new Class2();
                    break;

                case 'mssql':
                    return new Class3();
                    break;
                default:
                    return Signal::getInstance();

            }
        }
    }

    interface Connect
    {
        public function fun1($param);
    }

    class Class1 implements Connect
    {
        public function fun1($param)
        {
            //具体实现
        }
    }

    class Class2 implements Connect
    {
        public function fun1($param)
        {
            //具体实现
        }
    }

    class Class3 implements Connect
    {
        public function fun1($param)
        {
            //具体实现
        }
    }

    /**
    *注册树模式
    */
    class Register
    {    
        static protected $objects;

        /**
        * 插入对象实例
        * @param string $alias 
        * @param object $object 对象实例
        */
        public static function set($alias,$object)
        {
            self::$objects[$alias]=$object;
        }

        /**
        * 撤销对象实例
        * @param string $alias
        */
        public static function _unset($alias)
        {
            unset(self::$objects[$alias]);
        }

        /**
        * 获取对象实例
        * @param string $alias
        * return object
        */
        public static function get($alias)
        {
            return self::$objects[$alias];
        }
    }

    Register::set('signal',Db::factory());
    $signal=Register::get('signal');
    $signal->connect();
?>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值