PHP设计模式之单例模式详解

单例模式

简单的说,一个对象只负责一个特定的任务,一个接口,一个连接池

单例类:

1、构造函数需要标记为private(访问控制:防止外部代码使用new操作符创建对象),单例类不能在其他类中实例化,只能被其自身实例化;

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

3、拥有一个访问这个实例的公共的静态方法(常用getInstance()方法进行实例化单例类,通过instanceof操作符可以检测到类是否已经被实例化)

另外,需要创建__clone()方法防止对象被复制(克隆)

为什么要使用PHP单例模式?

1、php的应用主要在于数据库应用, 所以一个应用中会存在大量的数据库操作, 使用单例模式, 则可以避免大量的new 操作消耗的资源。

2、如果系统中需要有一个类来全局控制某些配置信息, 那么使用单例模式可以很方便的实现。

3、在一次页面请求中, 便于进行调试, 因为所有的代码(例如数据库操作类db)都集中在一个类中, 我们可以在类中设置钩子, 输出日志,从而避免到处var_dump, echo

代码如下:

<?php  
  
class DB    
{    
    private static $_instance;        
    private function __construct()    
    {        
    }    
    
    private function __clone() {};  //覆盖__clone()方法,禁止克隆        
    public static function getInstance()    
    {    
        if(! (self::$_instance instanceof self) ) {    
            self::$_instance = new self();    
        }    
        return self::$_instance;    
    }    

实战如下:

    <?php  
    class db {  
        public $conn;  
        public static $sql;  
        public static $instance=null;  
        private function __construct(){  
            require_once('db.config.php');  
            $this->conn = mysql_connect($db['host'],$db['user'],$db['password']);  
            if(!mysql_select_db($db['database'],$this->conn)){  
                echo "失败";  
            };  
            mysql_query('set names utf8',$this->conn);         
        }  
        public static function getInstance(){  
            if(is_null(self::$instance)){  
                self::$instance = new db;  
            }  
            return self::$instance;  
        }  
        /** 
         * 查询数据库 
         */  
        public function select($table,$condition=array(),$field = array()){  
            $where='';  
            if(!empty($condition)){  
                  
                foreach($condition as $k=>$v){  
                    $where.=$k."='".$v."' and ";  
                }  
                $where='where '.$where .'1=1';  
            }  
            $fieldstr = '';  
            if(!empty($field)){  
                  
                foreach($field as $k=>$v){  
                    $fieldstr.= $v.',';  
                }  
                 $fieldstr = rtrim($fieldstr,',');  
            }else{  
                $fieldstr = '*';  
            }  
            self::$sql = "select {$fieldstr} from {$table} {$where}";  
            $result=mysql_query(self::$sql,$this->conn);  
            $resuleRow = array();  
            $i = 0;  
            while($row=mysql_fetch_assoc($result)){  
                foreach($row as $k=>$v){  
                    $resuleRow[$i][$k] = $v;  
                }  
                $i++;  
            }  
            return $resuleRow;  
        }  
        /** 
         * 添加一条记录 
         */  
         public function insert($table,$data){  
            $values = '';  
            $datas = '';  
            foreach($data as $k=>$v){  
                $values.=$k.',';  
                $datas.="'$v'".',';  
            }  
            $values = rtrim($values,',');  
            $datas   = rtrim($datas,',');  
            self::$sql = "INSERT INTO  {$table} ({$values}) VALUES ({$datas})";  
            if(mysql_query(self::$sql)){  
                return mysql_insert_id();  
            }else{  
                return false;  
            };  
         }  
         /** 
          * 修改一条记录 
          */  
        public function update($table,$data,$condition=array()){  
            $where='';  
            if(!empty($condition)){  
                  
                foreach($condition as $k=>$v){  
                    $where.=$k."='".$v."' and ";  
                }  
                $where='where '.$where .'1=1';  
            }  
            $updatastr = '';  
            if(!empty($data)){  
                foreach($data as $k=>$v){  
                    $updatastr.= $k."='".$v."',";  
                }  
                $updatastr = 'set '.rtrim($updatastr,',');  
            }  
            self::$sql = "update {$table} {$updatastr} {$where}";  
            return mysql_query(self::$sql);  
        }  
        /** 
         * 删除记录 
         */  
         public function delete($table,$condition){  
            $where='';  
            if(!empty($condition)){  
                  
                foreach($condition as $k=>$v){  
                    $where.=$k."='".$v."' and ";  
                }  
                $where='where '.$where .'1=1';  
            }  
            self::$sql = "delete from {$table} {$where}";  
            return mysql_query(self::$sql);  
              
         }  
          
        public static function getLastSql(){  
            echo self::$sql;  
        }  
          
          
          
    }  
      
    $db = db::getInstance();  
    //$list = $db->select('demo',array('name'=>'tom','password'=>'ds'),array('name','password'));  
    //echo $db->insert('demo',array('name'=>'最近你啦','password'=>'123'));  
    //echo $db->update('demo',array("name"=>'xxx',"password"=>'123'),array('id'=>1));  
    echo $db->delete('demo',array('id'=>'2'));  
    db::getLastSql();  
    echo "<pre>";  
    ?>  

 

转载于:https://my.oschina.net/u/3058368/blog/790751

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值