单例模式数据库php 单例模式编写( 二 )


protected static $db;
//这里构造函数一定要是私有方法
private function __construct()
{
}
//声明一个获取类实例的方法
static function getInstace()
{
if(self::$db) {
return self::$db;
}else {
//生成自己
self::$db = new self();
return self::$db;
}
}
}
//错误调用方法
//用new实例化private标记构造函数的类会报错
$db = new Database();
//正确获取实例方法
$db = Database::getInstace();
使用单例模式的好处是,当你在其他地方也要使用到这个类 , 比如上面的数据库类 。那么你可以在其它地方直接调用 Database::getInstace(),而且该实例只会被生成一次,不会被重复生成,所以不会浪费系统资源 。
简单的说,单例模式生成的实例只被生成一次,而且只负责一个特定的任务 。
使用单例模式有下面几个要求:
1.构造函数需要标记为private(访问控制:防止外部代码使用new操作符创建对象),单例类不能在其他类中实例化,只能被其自身实例化;
2.拥有一个保存类的实例的静态成员变量;
3.拥有一个访问这个实例的公共的静态方法(常用getInstance()方法进行实例化单例类 , 通过instanceof操作符可以检测到类是否已经被实例化);
4.如果严谨的话,还需要创建__clone()方法防止对象被复制(克?。?。(我上面没创建)
使用单例模式好处 , 总结:
1、php的应用主要在于数据库应用, 所以一个应用中会存在大量的数据库操作, 使用单例模式, 则可以避免大量的new 操作消耗的资源 。
2、如果系统中需要有一个类来全局控制某些配置信息, 那么使用单例模式可以很方便的实现. 这个可以参看ZF的FrontController部分 。
3、在一次页面请求中, 便于进行调试 。
参考:
单例模式 数据库 php 怎么用搭建好php开发环境单例模式数据库php,这个就不多讲单例模式数据库php了,能找单例模式的应该有一定的php基础
2
新建一个database.php文件存放数据库信息
?php
$db = array(
'host'='localhost',//地址
'user'='root',//数据库用户名
'password'='root',//数据库密码
'database'='ceshi',//数据库名
)
?
3
新建Mysql.class.php编写数据库连接类操作类添加需要的属性和构造方法
构造函数加载数据库配置文件连接数据库
?php
class db {
public $conn;
public static $sql;
public static $instance=null;
private function __construct(){
require_once('database.php');
$this-conn = mysqli_connect($db['host'],$db['user'],$db['password']);
if(!mysqli_select_db($this-conn,$db['database'])){
echo "失败";
};
mysqli_query($this-conn,'set names utf8');
}
}
?这样试试吧如果单例模式数据库php你对php这类有兴趣的话,可以和我一样在后盾人经常看看教材,自己多看几遍 , 慢慢的以后就明白了 , 希望能帮到你,给个采纳吧谢谢
【单例模式数据库php 单例模式编写】关于单例模式数据库php和单例模式编写的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息 , 记得收藏关注本站 。

推荐阅读