gpt4 book ai didi

php - 单例 PHP - 数据库处理程序

转载 作者:可可西里 更新时间:2023-11-01 12:33:57 27 4
gpt4 key购买 nike

我最近读了一些关于单例模式的文章。当阅读它的技术方面时,它似乎非常适合管理数据库处理程序等。但在阅读了更广泛的资源后,开发者社区似乎并不喜欢这种模式。

我正在努力寻找解决此类问题的更好方法——即一次只能初始化一个处理程序——那么为什么模式如此糟糕?它是被过度使用还是存在根本性缺陷?

PHP 是我使用的语言。

最佳答案

Singletons are glorified global variables .该设计模式是为全局变量很难或不可能的语言创建的,或者它们被认为是不好的做法。 (事实上​​ ,大多数常见的设计模式都是为限制性语言设计的。其中很多在其他语言中根本不需要。)

PHP 有全局变量。 PHP 全局变量通常是一种不好的做法,但如果您需要使用它们,它们确实存在。

但是,有几个原因让您需要 PHP 中的单例。

当调用 getInstance(返回单个实例的方法的规范名称)时,我可以在脚本中的任何位置调用单例。到那时为止,该对象不需要存在。如果对象是一个全局变量,要么它必须已经存在,要么试图引用该对象的代码首先需要实例化它。事实上,在任何可以使用它的地方,都需要正确地实例化它。通过在 getInstance 中集中创建单个对象,您可以避免每次需要引用对象时都必须创建复制粘贴样板文件。

数据库对象通常是在请求生命周期的早期创建的,因此会浪费单例性的特定优势。

除了 Singleton 之外,还有其他替代方案可以以其他方式完成工作。一个例子是 dependency injection ,一个奇特的术语,用于在构造时将新对象所依赖的外部对象(例如数据库句柄)传递给对象。但是,这可能很复杂或令人讨厌。正确的做法可能涉及每次都注入(inject)很多相同的对象。

另一种选择是 Registry pattern ,它实际上是一个容器,用于存放本来是全局变量的东西。如果您不喜欢全局变量,但不介意它们被有效地命名空间化,这将是您想要的解决方案。

最后,选择一种方法,并在整个代码库中坚持使用这种方法。就个人而言,我喜欢数据库对象是全局的。

关于php - 单例 PHP - 数据库处理程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3277305/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com