php设计模式-单例模式

简介:

只允许该类自己创建该类的唯一对象,防止直接创建对象和克隆 对外暴露一个统一的接口,通过静态方法获取该对象 该类防止被直接创建和克隆

优点:

new对象的操作过多会消耗内存,使用单例模式生成一个对象后, 该对象可以被其它众多对象所使用

使用场景:

一般用于数据库操作类

实例:

/**
 * 该类自己创建该类的唯一对象,防止直接创建对象和克隆
 * 对外暴露一个统一的接口,用于获取该对象
 * 单例数据库连接(mysqli为例)
 */
class Db
{
    //static可以保存值不丢失
    private static $_instance;

    private static $_dbConnect;

    private $_dbConfig = array(
        'host' => '127.0.0.1',
        'user' => 'root',
        'password' => '123456',
        'database' => 'wangxiao_test'
    );

    //使用private防止用户new
    private function __construct()
    {
    }

    //防止用户进行clone
    private function __clone()
    {
        //当用户clone操作时产生一个错误信息
        trigger_error("Can't clone object", E_USER_ERROR);
    }

    //静态类的自身来进行实例化
    public static function getInstance()
    {
        if (!(self::$_instance instanceof self)) {
            self::$_instance = new self();
        }
        return self::$_instance;
    }


    /**
     * @brief 连接数据库(mysqli)
     * @throws Exception
     */
    public function connect()
    {
        self::$_dbConnect = @new mysqli($this->_dbConfig['host'], $this->_dbConfig['user'], $this->_dbConfig['password']);
        if (!self::$_dbConnect) {
            throw new Exception("mysql connect error" . mysqli_connect_error());
        }
        self::$_dbConnect->query("set names 'utf8';");//编码转化
        mysqli_select_db(self::$_dbConnect, $this->_dbConfig['database']);
        return self::$_dbConnect;
    }
}

// 具体调用
$mysqli = Db::getInstance();
try {
    $coon = $mysqli->connect();
    $sql = 'select * from users limit 10';
    $res = mysqli_query($coon, $sql);
    while ($row = mysqli_fetch_assoc($res)) {
        var_dump($row);
    }
} catch (Exception $e) {
    echo "sorry,error was happened." . $e->getMessage();
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值