欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

基础编程:关于单例模式的有关问题,大牛进来撸~

程序员文章站 2022-06-09 10:58:09
...
基础编程:关于单例模式的问题,大牛进来撸~~~
class Example
{
// 保存类实例在此属性中
private static $instance;

// 构造方法声明为private,防止直接创建对象
private function __construct()
{
echo 'I am constructed
';
}

// singleton 方法
public static function singleton()
{
if(!isset(self::$instance))
{
$c=__CLASS__;
self::$instance=new $c;
}

return self::$instance;
}



// Example类中的普通方法
public function bark()
{
echo 'Woof!';
}

// 阻止用户复制对象实例
public function __clone()
{
trigger_error('Clone is not allowed.', E_USER_ERROR);
}

public function destroy()
{
unset(self::$instance);
}

}


// 这个写法会出错,因为构造方法被声明为private
//$test = new Example;


// 下面将得到Example类的单例对象
$test = Example::singleton();
$test->bark();

// 复制对象将导致一个E_USER_ERROR.
//$test_clone = clone $test;


$b=Example::singleton();

$b->destroy();

?>


原文:http://www.php.net/manual/zh/language.oop5.patterns.php


这里我想问:

1) $b=Example::singleton(); 是生成一个新的对象 ,还是

$test 和 $b 都指向 Example::singleton() 这个生成的对象?


2) 为什么我 的 destroy() 方法会出错?有没什么办法可以销毁 Example::singleton() 这个对象或说令它变成null,

是不是这样就使得 $test 和 $b 同时变成了 null?



------解决方案--------------------
是private function __clone吧,单例的释放也不应该是析构函数做的,概念完全混淆了,应该提供独立的public static接口来释放单例对象。

1,同一个对象
2,上边已经说了,不会变成null的,你不应该再使用那两个变量了,因为对象是引用。
------解决方案--------------------
写了个小测试
PHP code
------解决方案--------------------
自己也试了一下,一个对象自身一个引用,变量再引用就是2个引用,所以null和一开始的$i是这样情况,不知道对不对,不过对不对也不重要了。


------解决方案--------------------
探讨
2) 为什么我 的 destroy() 方法会出错?有没什么办法可以销毁 Example::singleton() 这个对象或说令它变成null,
基础编程:关于单例模式的有关问题,大牛进来撸~

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

相关文章

相关视频