<?php
/*
场景:
class mysql {
}
$my1 = new mysql();
$my2 = new mysql();
$my3 = new mysql();
每new一次,连接一次数据库
同时,多了一个对象,增大的开销
另一种场景:购物车
如果我打开多个页面,每个页面实例了多个购物车
那么下的订单,可能会被装在不同的购物车里,出现错误.
所以,购物车,也得保证,只有有一个实例.
问:如何保证让大家使的$my1,$my2,$my3,是同一个对象?
*/
//类的静态属性
//类的静态属性和其他属性不一样
/*
class human{
static public $leg=2;
public $name;
public function __construct($name){
$this->name=$name;
}
public function showlegs(){
echo self::$leg;
}
}
$zhangsan=new human('张三');
$lisi=new human('李四');
print_r($zhangsan);// 多个对象,就有多个name普通属性.
print_r($lisi);
$lisi->showlegs();
*/
/*
class human{
static public $leg=2; // 这个数字2不属于张三,不属于李四,而属于全人类
static public function ins(){
echo 'aaa';
echo self::$leg;
//echo $this->name;// Using $this when not in object context self 是指类本身 $this是指对象本身
}
public $name;
public function _construct($name){
$this->name=$name;
}
public function showleg(){
echo self::$leg;
}
}
$zhangsan=new human('张三');
$lisi=new human('李四');
// 不创建任何实例/对象, 调用human的$leg静态属性
human::ins();
/*
1:静态属性/方法,属于全类,而不属于对象.
2:在内存中,只有一份.
3:调用静态属性/方法,用类名::$属性名,类名::方法名()来调用, 不依赖对象
*/
//单例模式第0步
/*
class mysql{
public $rand;
public function __construct(){
$this->rand=rand(10000,99999);
}
}
$m1=new mysql();
$m2=new mysql();
print_r($m1);
print_r($m2);
*/
//单例模式第一步不允许进行new操作
/*
class mysql{
public $rand;
protected function __construct($rand){
$this->rand=$rand;
}
}
$m1=new mysql;
*/
//在类中开放一个借口进行实例化对象
/*
class mysql{
public $rand;
static function ins(){
return new mysql;
}
protected function __construct(){
$this->rand=rand(1000,9999);
}
}
$m1=mysql::ins();
$m2=mysql::ins();
print_r($m1);
print_r($m2);
*/
// 单例模式第3步,加判断,判断该类的实例是否已经存在.
class mysql{
public $rand;
static public $flag=null;
static function ins(){
if(self::$flag){
self::$flag=new mysql;
return self::$flag;
}
return self::$flag;
}
final protected function __construct(){
$this->rand=rand(1000,9999);
}
}
$m1=mysql::ins();
$m2=mysql::ins();
class my extends mysql{
public $name;
}
//$m1=new my();不能被new了
//$m2=new my();不能被new了
print_r($m1);
print_r($m2);
if($m1===$m2){
echo '是同一个对象';
}
else{
echo "不是一个对象";
}
// 问题:子类继承时,允许同名方法覆盖父类的同名方法,且权限越来越宽松.
// 某个方法,继承可以,但是不允许重写.
// final,关键字.可以修饰类名 方法名 修饰类名的时候不能继承 修饰方法的时候不能重写
//还有可能通过克隆得倒两个对象
?>