登录
首页 >  数据库 >  MySQL

PHP设计模式-Singleton 单例(单元素)模式

来源:SegmentFault

时间:2023-02-24 20:05:51 263浏览 收藏

来到golang学习网的大家,相信都是编程学习爱好者,希望在这里学习数据库相关编程知识。下面本篇文章就来带大家聊聊《PHP设计模式-Singleton 单例(单元素)模式》,介绍一下MySQL、Linux、nginx、PHP、centos,希望对大家的知识积累有所帮助,助力实战开发!

整理一下自己的学习Aaron Saray 写的PHP设计模式一些demo和自己的理解。大佬看完如果发现鄙人理解有误请立即指出,感谢拍砖,跪求鞭打

/**
 * Singleton  单例(单元素)模式实现
 * -------------------------------------
 * ** 来自说明 **
 * 
 * 通过提供对自身共享实例对访问,单元素(单例)设计模式用于限制特定对象只能被创建一次。
 * 此对象可能最多存储自身的5个实例,如果出现第6个请求,那么不得不等待。
 * 或者只是提供对先前创建的5个实例之一的引用在排队请求中,这种体系结构类型特别有用
 * 
 * ===================================== 
 * ** 应用场景 **
 * 
 * 最常用于数据库连接对象,数据库访问对象可以负责创建一个与数据库的实例化连接。
 * 接下来,只要调用这个对象的特定方法,该对象就会使用已成功创建的连接。
 * 从而减少服务器开销 
 * -------------------------------------
 * 
 * @version ${Id}$
 * @author Shaowei Pu 
 */


     * @CreateTime    2017-02-08T11:20:19+0800
     * @return                              [type] [description]
     */
    private function __clone(){}

    /**
     * [__construct 不能new啦]
     * @author         Shaowei Pu 
     * @CreateTime    2017-02-08T11:18:09+0800
     */
    private function __construct(){
        try{
            $this->pdo =new \PDO("mysql:dbname=数据库名字;host=127.0.0.1,root,123456");
            $this->pdo->exec('SET NAMES utf8');//设置通信编码
            $this->pdo->setAttribute(\PDO::ATTR_ERRMODE, \PDO::ERRMODE_EXCEPTION);
        }catch(PDOException $e){
            die('error:'.$e->getMessage());
        }   
      }
      /**
       * [getinstance 单例开始]
       * @author         Shaowei Pu 
       * @CreateTime    2017-02-08T11:21:31+0800
       * @return                              [type] [description]
       */
      public static function getInstance(){
          // 检测其并不是本类实例
          if( !self::$_instance instanceof self ){
              self::$_instance = new self; 
          }
          return self::$_instance;
      }
      /**
       * [select 简单查询操作]
       * @author         Shaowei Pu 
       * @CreateTime    2017-02-08T12:11:06+0800
       * @param                               [type] $dbname [description]
       * @param                               [type] $filed  [description]
       * @param                               [type] $where  [description]
       * @return                              [type]         [description]
       */
    public function select($dbname,$filed,$where)
    {
        $stmt = self::$_pdo ->prepare(" SELECT {$filed} FROM {$dbname} {$where}");
        $stmt->execute();
          return $stmt->fetchAll(PDO::FETCH_ASSOC);
    }

}
Singleton::getInstance();

以上就是《PHP设计模式-Singleton 单例(单元素)模式》的详细内容,更多关于mysql的资料请关注golang学习网公众号!

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>