若是有实例,就拿实例,没有就建立实例,不容许外部建立实例php
16 public static function getInstance(){ 17 if (!self::$_instance instanceof self) { 18 # code... 19 self::$_instance=new self; 20 } 21 22 return self::$_instance; 23 }
其实均可以,感受用null要好,语义,判断是否用false,参数是数据的话就是nullmysql
定时把数据的数据弄到缓存中,也就是静态文件中,这样就能够保证用户一直在文件中读取最新数据,而不用链接数据库。sql
1)构造函数须要标记为非public(防止外部使
用new操做符建立对象),单例类不能在其余类中实
例化,只能被其自身实例化。
2)拥有一个保存类的实例的静态成员变量
$_instance。
3)拥有一个访问这个实例的公告的静态方法数据库
1)读取数据库方式开发首页接口缓存
2)读取缓存方式开发首页接口服务器
优点:减小数据库压力函数
3)定时的读取缓存方式开发首页接口fetch
1 <?php 2 3 class DB{ 4 const HOST='localhost'; 5 const USER='root'; 6 const PASS='123'; 7 const DATA='feifei'; 8 static public $_instance; 9 10 private function __construct(){ 11 @mysql_connect(DB::HOST,DB::USER,DB::PASS); 12 mysql_set_charset('utf8'); 13 mysql_select_db(DB::DATA); 14 } 15 16 public static function getInstance(){ 17 if (!self::$_instance instanceof self) { 18 # code... 19 self::$_instance=new self; 20 } 21 22 return self::$_instance; 23 } 24 } 25 26 // $model=new DB(); 27 28 // $model=DB::getInstance(); 29 30 // $sql="select * from user"; 31 // $res=mysql_query($sql); 32 // while ($row=mysql_fetch_assoc($res)) { 33 // # code... 34 // var_dump($row); 35 // } 36 37 38 39 40 ?>