编程 PHP设计模式:单例模式

2024-11-18 18:31:43 +0800 CST views 919

PHP设计模式:单例模式

目的

在整个应用程序的生命周期内(从脚本启动到结束),只能获得单例类的一个对象实例。
单例模式常用于如数据库连接等场景,多个类可以共用一个数据库连接对象,而不必每次都去 new 一个新对象,这样可以避免连接数递增导致的资源浪费。


实现原理

单例模式通过以下几个关键点来实现:

  1. 私有化 __construct 构造函数:防止外部通过 new 创建多个实例。
  2. 私有化 __clone:防止外部克隆实例,创建副本。
  3. 私有化 __wakeup:防止反序列化创建新的实例。
  4. 提供静态方法 getInstance():用于返回该类的唯一实例。

代码实现

class Singleton
{
    /**
    * @var Singleton 唯一实例
    */
    private static $instance;

    /**
    * 获取实例的静态方法,通过懒加载在第一次使用时创建实例
    *
    * @return Singleton 唯一实例
    */
    public static function getInstance(): Singleton
    {
        if (null === static::$instance) {
            static::$instance = new static();
        }
        return static::$instance;
    }

    /**
    * 构造函数私有化,防止从外部创建新的实例
    */
    private function __construct()
    {
    }

    /**
    * 禁止克隆,防止外部克隆对象
    */
    private function __clone()
    {
    }

    /**
    * 禁止反序列化,防止通过反序列化创建新实例
    */
    private function __wakeup()
    {
    }
}

测试

$singleton1 = Singleton::getInstance();
var_dump($singleton1);

$singleton2 = Singleton::getInstance();
var_dump($singleton2);

// 尝试直接实例化将会抛出错误
$singleton3 = new Singleton();
var_dump($singleton3);

测试结果

object(Singleton)#1 (0) {
}
object(Singleton)#1 (0) {
}

Fatal error: Uncaught Error: Call to private Singleton::__construct() 

从测试结果可以看到:

  • $singleton1$singleton2 是同一个对象实例,表明单例模式成功实现。
  • $singleton3 由于直接实例化而报错,验证了通过私有化 __construct 限制了外部创建多个实例。

总结

通过单例模式,我们可以确保在应用程序的生命周期中,某个类只能有一个对象实例。这样的设计在需要共享资源(例如数据库连接、日志管理等)时尤为重要,能够节省资源、提高系统性能。

复制全文 生成海报 设计模式 PHP 编程

推荐文章

go命令行
2024-11-18 18:17:47 +0800 CST
任务管理工具的HTML
2025-01-20 22:36:11 +0800 CST
JavaScript设计模式:适配器模式
2024-11-18 17:51:43 +0800 CST
Vue3 实现页面上下滑动方案
2025-06-28 17:07:57 +0800 CST
PHP来做一个短网址(短链接)服务
2024-11-17 22:18:37 +0800 CST
php内置函数除法取整和取余数
2024-11-19 10:11:51 +0800 CST
用 Rust 构建一个 WebSocket 服务器
2024-11-19 10:08:22 +0800 CST
一个简单的html卡片元素代码
2024-11-18 18:14:27 +0800 CST
Gin 与 Layui 分页 HTML 生成工具
2024-11-19 09:20:21 +0800 CST
在 Rust 生产项目中存储数据
2024-11-19 02:35:11 +0800 CST
Vue3中的事件处理方式有何变化?
2024-11-17 17:10:29 +0800 CST
15 个 JavaScript 性能优化技巧
2024-11-19 07:52:10 +0800 CST
CSS Grid 和 Flexbox 的主要区别
2024-11-18 23:09:50 +0800 CST
Nginx 防盗链配置
2024-11-19 07:52:58 +0800 CST
程序员茄子在线接单