首页后端开发PHP单例是什么,php中是什么意思

单例是什么,php中是什么意思

时间2024-03-23 23:54:03发布访客分类PHP浏览565
导读:关于“单例是什么,php中是什么意思”的知识点有一些人不是很理解,对此小编给大家总结了相关内容,文中的内容简单清晰,易于学习与理解,具有一定的参考学习价值,希望能对大家有所帮助,接下来就跟随小编一起学习一下“单例是什么,php中是什么意思”...
关于“单例是什么,php中是什么意思”的知识点有一些人不是很理解,对此小编给大家总结了相关内容,文中的内容简单清晰,易于学习与理解,具有一定的参考学习价值,希望能对大家有所帮助,接下来就跟随小编一起学习一下“单例是什么,php中是什么意思”吧。

在PHP中,单例是一个类有且只有一个实例的意思,是指整个应用中的某个类只有一个对象实例的设计模式;单例模式中自行实例化会向整个系统全局提供这个实例,不会创建实例副本,而是会向单例类内部存储的实例返回一个引用。

本文操作环境:Windows10系统、PHP7.1版、Dell G3电脑

php中的单例是什么意思

单例模式是指整个应用中某个类只有一个对象实例的设计模式。具体来说,作为对象的创建方式,单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统全局的提供这个实例。它不会创建实例副本,而是会向单例类内部存储的实例返回一个引用。

一个类有且仅有一个实例,并且自行实例化后提供给整个程序使用,或者可以理解为在整个程序运行期间,保证这个类有且仅一个实例,并对外提供一个能够访问它的全局访问点。

单例模式的特点

单例模式的主要特点是“三私一公”:

需要一个保存类的唯一实例的私有静态成员变量

构造函数必须声明为私有的,防止外部程序new一个对象从而失去单例的意义

克隆函数必须声明为私有的,防止对象被克隆

必须提供一个访问这个实例的公共静态方法(通常命名为getInstance),从而返回唯一实例的一个引用。

使用单例模式的原因及场景

在PHP的大多数应用中都会存在大量的数据库操作,如果不用单例模式,那每次都要new操作,但是每次new都会消耗大量的系统资源和内存资源,而且每次打开和关闭数据库都是对数据库的一种极大考验和浪费。所以单例模式经常用在数据库操作类中。

同样,如果系统中需要有一个类来全局控制某些配置信息,那使用单例模式可以很方便的实现。

PHP单例模式实现

下面是一个PHP单例模式实现数据库操作类的框架

?php
 class Db{
    
 const DB_HOST='localhost';
    
 const DB_NAME='';
    
 const DB_USER='';
    
 const DB_PWD='';
    
 private $_db;
    
 //保存实例的私有静态变量
 private static $_instance;

 //构造函数和克隆函数都声明为私有的
 private function __construct(){
    
  //$this->
    _db=mysql_connect();

 }

 private function __clone(){

  //实现
 }

 //访问实例的公共静态方法
 public static function getInstance(){

  if(!(self::$_instance instanceof self)){
    
  self::$_instance=new self();

  }

  //或者
  if(self::$_instance===null){
    
  self::$_instance=new Db();

  }
    
  return self::$_instance;

 }

 public function fetchAll(){

  //实现
 }

 public function fetchRow(){

  //实现
 }

 }
    
 //类外部获取实例的引用
 $db=Db::getInstance();
    
?>
    



感谢各位的阅读,以上就是“单例是什么,php中是什么意思”的内容了,通过以上内容的阐述,相信大家对单例是什么,php中是什么意思已经有了进一步的了解,如果想要了解更多相关的内容,欢迎关注网络,网络将为大家推送更多相关知识点的文章。

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

php

若转载请注明出处: 单例是什么,php中是什么意思
本文地址: https://pptw.com/jishu/651682.html
MySQL中UPDATE语句基本用法是什么 MySQL单表分页性能怎么样优化

游客 回复需填写必要信息