PHP单例模式解析与实战

一、什么是单例模式?

    1:含义

     作为对象的创建模式,单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统全局的提供这个实例。它不会创建实例副本,而是会向单例类内部存储的实例返回一个引用。

    2:单例模式的三个要点

        ①、需要一个保存类的唯一实例的静态成员变量

    private static $_instance;

        ②、构造函数和克隆函数必须声明为私有,防止外部程序new类,从而失去单例模式的意义

    private function __construct()
    {
        $this->_db = pg_connet('xxxx');
    } 
    private function __clone()
    {
        //覆盖__clone()方法,禁止克隆
    }

        ③、必须提供一个访问这个实例的公共的静态方法(通常为getInstance方法),从而返回唯一实例的一个引用

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

二、为什么要使用单例模式?

    1:PHP缺点

     PHP语言是一种解释型的脚本语言,这种运行机制使得每个PHP页面被解释执行后,所有的相关资源都会被回收。也就是说,PHP在语言级别上没有办法让某个对象常驻内存,这和asp.net、Java等编译型是不同的,比如在Java中单例会一直存在于整个应用程序的生命周期里,变量是跨页面级的,真正可以做到这个实例在应用程序生命周期中的唯一性。然而在PHP中,所有的变量无论是全局变量还是类的静态成员,都是页面级的,每次页面被执行时,都会重新建立新的对象,都会在页面执行完毕后被清空,这样似乎PHP单例模式就没有什么意义了,所以PHP单例模式我觉得只是针对单次页面级请求时出现多个应用场景并需要共享同一对象资源时是非常有意义的。

    2:单例模式在PHP中的应用场合

        ①、应用程序与数据库交互

         一个应用中会存在大量的数据库操作,比如过数据库句柄来连接数据库这一行为,使用单例模式可以避免大量的new操作,因为每一次new操作都会消耗内存资源和系统资源。

        ②、控制配置信息

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

三、如何实现单例模式

    1:普通的数据库访问的例子

<?php  
......  
//初始化一个数据库句柄  
$db = new DB(...);  
  
//添加用户信息  
$db->addUserInfo(...);  

  
//在函数中访问数据库,查找用户信息  
function getUserInfo()  
{  
    $db = new DB(...);//再次new 数据库类,和数据库建立连接  
    $db = query(....);//根据查询语句访问数据库 
}
 
?>

 2:应用单例模式对数据库进行操作

<?php  
class DB    
{    
    private $_db;    
    private static $_instance;    
    
    private function __construct(...)    
    {    
        $this->_db = pg_connect(...);//postgrsql    
    }    
    
    private function __clone() {};  //覆盖__clone()方法,禁止克隆    
    
    public static function getInstance()    
    {    
        if(! (self::$_instance instanceof self) ) {    
            self::$_instance = new self();    
        }    
        return self::$_instance;    
    } 
    public function addUserInfo(...)  
    { 
    }  
  
     public function getUserInfo(...)  
    {   
    } 
} 
//test  
  
$db = DB::getInstance();  
  
$db->addUserInfo(...);  
  
$db->getUserInfo(...);  
?>

      3:深入理解

<?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/ZKXTtiumph/blog/634277

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值