ホームページ > バックエンド開発 > PHPチュートリアル > PHP シングルトン モード (責任モード)

PHP シングルトン モード (責任モード)

高洛峰
リリース: 2023-03-05 15:56:02
オリジナル
1454 人が閲覧しました

簡単に言えば、オブジェクト (デザイン パターンを学ぶ前に、オブジェクト指向の考え方を理解する必要があります) は、特定のタスクのみを担当します。

単一インスタンス クラス:

1. コンストラクターはプライベートとしてマークする必要があります。コードは new 演算子を使用してオブジェクトを作成します)。シングルトン クラスは他のクラスでインスタンス化できませんが、それ自体でのみインスタンス化できます。

2. クラスのインスタンスを保存する静的メンバー変数があります。インスタンスのパブリック静的メソッドにアクセスする方法を用意します (getInstance() メソッドはシングルトン クラスをインスタンス化するためによく使用され、instanceof 演算子はクラスがインスタンス化されたかどうかを検出するために使用できます)

さらに、 __clone( ) オブジェクトがコピー (クローン) されるのを防ぐためにメソッドを作成する必要があります。 )

<?php
/**
 * Created by PhpStorm.
 * User:
 * Date: 2017/1/2
 * Time: 下午3:32
 */

class Single {
    //保存实例的私有静态实例变量
    private static $instance;

    //private标记的构造方法,方式通过其他方式实例化
    private function __construct() {
        echo "this is construct function";
    }

    //创建clone方法防止被克隆
    public function __clone() {
        trigger_error("Clone is not allowed ", E_USER_ERROR);
    }

    //单例方法,用户访问实例的公共静态方法
    public static function shareInstance() {
        //instanceof:判断instance是不是self的实例或者子类
        if (!(self::$instance instanceof self)){
            self::$instance = new self();
        }
        return self::$instance;
    }
}
ログイン後にコピー
ログイン後にコピー

attached

trigger_error() 関数はユーザーレベルのエラー メッセージを作成します。

trigger_error() 関数を組み込みエラー ハンドラーに関連付けることも、ユーザー定義関数を新しいエラー ハンドラー (set_error_handler()) として使用することもできます。 trigger_error() 函数创建用户级别的错误消息。

trigger_error() 函数能结合内置的错误处理器所关联,或者可以使用用户定义的函数作为新的错误处理程序(set_error_handler())。

trigger_error(errormsg,errortype);
ログイン後にコピー
ログイン後にコピー
参数 描述
errormsg 必需。规定错误消息。最大长度 1024 字节。
errortype 可选。规定错误类型。可能的值:E_USER_ERRORE_USER_WARNINGE_USER_NOTICE(默认)


简单的说,一个对象(在学习设计模式之前,需要比较了解面向对象思想)只负责一个特定的任务;

单例类:

1、构造函数需要标记为private(访问控制:防止外部代码使用new操作符创建对象),单例类不能在其他类中实例化,只能被其自身实例化;

2、拥有一个保存类的实例的静态成员变量

3、拥有一个访问这个实例的公共的静态方法(常用getInstance()方法进行实例化单例类,通过instanceof操作符可以检测到类是否已经被实例化)

另外,需要创建__clone()方法防止对象被复制(克隆)

<?php
/**
 * Created by PhpStorm.
 * User:
 * Date: 2017/1/2
 * Time: 下午3:32
 */

class Single {
    //保存实例的私有静态实例变量
    private static $instance;

    //private标记的构造方法,方式通过其他方式实例化
    private function __construct() {
        echo "this is construct function";
    }

    //创建clone方法防止被克隆
    public function __clone() {
        trigger_error("Clone is not allowed ", E_USER_ERROR);
    }

    //单例方法,用户访问实例的公共静态方法
    public static function shareInstance() {
        //instanceof:判断instance是不是self的实例或者子类
        if (!(self::$instance instanceof self)){
            self::$instance = new self();
        }
        return self::$instance;
    }
}
ログイン後にコピー
ログイン後にコピー

trigger_error() 函数创建用户级别的错误消息。

trigger_error()

trigger_error(errormsg,errortype);
ログイン後にコピー
ログイン後にコピー
パラメータ説明必須。エラーメッセージを指定します。最大長は 1024 バイト。 オプション。エラーの種類を指定します。可能な値: E_USER_ERRORE_USER_WARNINGE_USER_NOTICE (デフォルト)


errormsg
エラータイプ

簡単に言えば、オブジェクト (デザイン パターンを学ぶ前に、オブジェクト指向の考え方を理解する必要があります) は責任のみを負います。特定のタスクの場合:

シングルトン クラス:

1. コンストラクターはプライベートとしてマークされる必要があります (アクセス制御: 外部コードがオブジェクトを作成するために new 演算子を使用できないようにします)。

🎜 2. クラスのインスタンスを保存する静的メンバー変数を持ちます 🎜🎜 3. このインスタンスにアクセスするためのパブリック静的メソッドを持ちます (通常、getInstance() メソッドは、 instanceof 演算子 (クラスがインスタンス化されているかどうかを検出できます)🎜🎜 さらに、オブジェクトがコピー (クローン) されるのを防ぐために __clone() メソッドを作成する必要があります🎜rrreee🎜🎜Attached🎜🎜🎜trigger_error() 関数はユーザー レベルのエラー メッセージを作成します。 🎜🎜 trigger_error() 関数を組み込みエラー ハンドラーに関連付けることも、ユーザー定義関数を新しいエラー ハンドラー (set_error_handler()) として使用することもできます。 🎜rrreee🎜🎜🎜🎜パラメータ🎜🎜説明🎜🎜🎜🎜🎜🎜🎜errormsg🎜🎜🎜必須。エラーメッセージを指定します。最大長は 1024 バイト。 🎜🎜🎜🎜🎜エラータイプ🎜🎜🎜オプション。エラーの種類を指定します。可能な値: E_USER_ERRORE_USER_WARNINGE_USER_NOTICE (デフォルト) 🎜🎜🎜🎜🎜🎜🎜PHP のシングルトン モード (責任モード) に関連するその他の記事については、PHP 中国語 Web サイトに注目してください。 🎜🎜🎜
関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート