PHP設計パターン(3):構造パターン
1. 構造パターンとは何ですか?
構造パターンとは、クラスやオブジェクトの内部構造や外部の組み合わせを解析し、プログラム構造を最適化することでモジュール間の結合問題を解決するものです。
2. 構造パターンの種類:
アダプター パターン
ブリッジ パターン
装飾パターン
コンビネーション パターン
外観パターン
フライウェイト パターン
エージェント パターン
1. アダプター パターン (Adapter)
クラスのインターフェイスを顧客が望む別のインターフェイスに変換します。アダプター パターンを使用すると、インターフェイスの互換性がないために元々連携できなかったクラスが連携できるようになります。
アプリケーション シナリオ: 古いコード インターフェイスが新しいインターフェイスの要件を満たしていないか、コードが複雑すぎて変更を続けることができないか、またはサードパーティのクラス ライブラリが使用されています。
コードの実装
- /** */
- {
- private $name; 🎜>
- 関数 __construct ($name) {
- $this->name = $name;
- }
- public function getName() {
- return $this- >name;
- }
- }
- 🎜> // 新しいコード、オープンプラットフォーム標準インターフェース>
- protected $user;
- function __construct($user) {
- $this->user = $user;
- }
- public function getUserName() { 🎜> $ olduser = new User('Zhang San');
- echo $olduser->getName()."n";
- $newuser = new UserInfo($olduser);
- echo $newuser->getUserName()."n";
- コードをコピー
- 注: ここでの新しいインターフェイスは次の組み合わせで使用します。この構造は実際には結合モードです。 UserInfo は User を継承することで同じ目的を達成できますが、結合度が高く、相互に影響を及ぼしますので、継承は使用しないでください。
- 2. ブリッジモード 抽象部分を実装部分から分離し、独立して変更できるようにします
- 特徴: 独立した存在、強力な拡張性 アプリケーション: 継続する必要がありますオブジェクトを呼び出しますが、同じ呼び出しメソッドを実行して拡張機能を実現します
- コードの実装
-
- /** */
- abstract class person {
- abstract function getJob();
- }
- class Student extends person {
- public function getJob() { 「学生」を返します。
- }
- }
- class Teacher extends person {
- public function getJob() {
- 戻る「老师」;
- }
- }
- class BridgeObj {
- protected $_person;
- public function setperson($person) {
- $this->_person = $person;
- }
- public function getJob() {
- return $this->_person->getJob();
- }
- }
- $obj = new BridgeObj();
- $obj->setperson(new Student());
- printf("今回桥接对象:%sn", $obj->getJob());
- $obj->setperson(new Teacher());
- printf("今回桥接对象:%sn", $obj->getJob());
- 复制代码
- 3、実装モード は、既存のオブジェクトに追加の機能を追加します。 :完全に保護されるのではなく、原オブジェクトの追加機能が必要な場合に使用されます
- 代码实现
- /**
- *
- * デコレーションモード
- *
- */
- // 製品
- ABSTRACT クラス パーソン {
- ABSTRACT FUNCTION GETPERMISSION ;
- } 'public Document'; >_user = $user;
- }
- public function getPermission() {
- return $this->_user->getPermission() 。 ;_special;
- }
- } 🎜>
- class CPlusUser extends PermUser {
- protected $_special = 'c++ プログラム';
- }
- User();
- printf("permission: %sn", $user->getPermission());
- $user = new JavaUser($user); >printf("許可:%sn", $user->getPermission());
- $user = new CPlusUser($user);
- printf("許可:%sn") , $user->getPermission());
- コードをコピー
- 装飾と継承の違いについて考えてみませんか?
- 上記の例の場合、継承が使用されている場合、CPlusUser は JavaUser を継承しますか、それともその逆ですか?エンドユーザーがどれを必要とするかは誰にもわかりません。 多層関係の場合、装飾は順序とは関係がなく、いつでも装飾を追加できますが、継承は特定の順序でのみ行うことができるため、装飾モードはより柔軟になります。
- 4. 結合モード
- オブジェクトをツリー構造に結合して、「部分全体」の階層構造を表現します。 機能: 強力な柔軟性
- アプリケーション: オブジェクトの部分と全体の階層、ファジー結合オブジェクト、単純なオブジェクト処理問題 コード実装
-
- /** */
- //继承モード
- class UserBaseInfo {
- プライベート $name;
- function __construct($name) {
- $this->name = $name;
- }
- public function getName() {
- return $this->name;
- }
- }
- class User extends UserBaseInfo {
- private $login = false;
- public function setLogin($islogin) {
- $this->login = $islogin;
- }
- public function isLogin() {
- return $this->login;
- }
- }
- $user = new User('张三');
- $user->setLogin(true);
- if ($user->isLogin()) {
- echo $user->getName()."已经登录了n";
- } else {
- echo $user->getName()."还没有登录n";
- }
- //組合わせモード
- クラス ログイン情報 {
- 保護された $user;
- protected $login = false;
- public setLogin($user, $isLogin) {
- $this->user = $user;
- $this->login = $isLogin;
- }
- public function isLogin() {
- return $this->login;
- }
- }
- $user = new User('Zhang San');
- $login = new LoginInfo();
- $login->setLogin ($user, true);
- if ($login->isLogin()) {
- echo $user->getName()."すでにログインしています";
- } else {
- echo $user->getName()."まだログインしていません"
- }
- / の部分は置き換え可能ですただし、継承はできません。
- class Admin {
- protected $level >level = $level;
- }
- $admin = 新しい管理者( 1);
- $login->setLogin($admin, true);
- if ($login-> isLogin()) {
- printf("レベル %d の管理者がログインしています n", $admin->getLevel());
- } else {
- printf("レベル %d の管理者はまだログインしていません", $admin->getLevel());
- }
- コードをコピー
- 上記の例はそれぞれ、新しい機能を処理するための継承と合成の違いは、単純な場合にはそれほど大きくないように見えますが、プロジェクトが後の段階でますます複雑になると、組み合わせモードの利点がますます明らかになります。
- 例えば、上記のログイン情報に、ログイン回数、最終ログイン時刻、ログインIPなどの情報を追加すると、ログイン自体がより複雑なオブジェクトになります。将来的に友人情報やユーザーのアクセス情報などの新たなニーズが発生し、それらを継承するとユーザークラスが非常に大きくなるのは必然であり、親との間で変数やメソッドが競合することは避けられません。クラスが多くなり、外部アクセスするユーザークラスも多くなり、その方法も手間がかかります。結合モードを採用すると、1 つのクラスが 1 つの役割を担当し、機能の区別が非常に明確になり、拡張が容易になります。
- 5. 外観モード (ファサード モード)
- システム内の一連のインターフェースに一貫したインターフェースを提供 機能: 上方抽出、共通性
- アプリケーション: 多数の内部インターフェース、統合インターフェース
によって呼び出されます
- class Operation {
- public function testPlus() { printf("plus: %sn", (1 + 2 == 3 ? 'true' : 'false'));
- }
- public function testMinus() {
- printf("minus: %sn", (3 - 2 == 2 ? 'true' : 'false') );
- }
- public function testTimes() {
- printf("times: %sn", (2 * 3 == 6 ? 'true' : 'false') );
- }
- }
- class Tester {
- protected $_operation;
- function __construct() {
- $this->_operation = new Operation();
- }
- public function testAll() {
- $this->_operation->testPlus();
- $this->_operation->testMinus();
- $this->_operation->testTimes();
- }
- }
- //测试用例、测试全接続口
- $tester = newテスター();
- $tester->testAll();
6. 共有要素モード
は、共有技術を使用して、大量の同じコンテンツ オブジェクトの開始を回避するために、大量の粒度のオブジェクトを効果的にサポートします。
特徴: 高効率、共有性
用途: システムの最下層の設計。 $str1=”abc”,$str2=”abc” の文字列は、最初の文字列を直接参照します。$str1=”abc”,$str2=”abc”。内部に保存されている文字列 “abc” のみが作成され、$str1 が参照されます。
7、プロキシモード
は、他のオブジェクトにプロキシを提供して、このオブジェクトを制御します。つまり、特定のオブジェクトにプロキシを提供し、プロキシオブジェクトによって特定のオブジェクトを制御します。
特徴: 低結合性、独立性、安全性
ゲスト: アクセスできない、またはアクセスされる
パスワードは、
を介して実行されます。- //内部オブジェクト
- class User {
- public function getName() {
- return 'Zhang San'; 🎜> }
- public function getType() {
- > //オープンプラットフォームなどのエージェントインターフェース定義
- インターフェース UserInterface {
- function getName();
- }
- // プロキシ オブジェクト
- クラス UserProxy 実装 UserInterface {
- protected $_user; >
- function __construct() {
- $this- >_user = new User( ; }
- }
- //内部呼び出し
- $user = new User();
- printf("ユーザー名: %sn" , $user->getName());
- printf("ユーザー タイプ: %sn", $user->getType());
- // 外部呼び出し
- // $user = new UserProxy();
- // printf ("ユーザー名: %sn", $user->getName());
- // printf ("ユーザー タイプ: %sn", $user->getType());アクセスするには、内部オブジェクトにこのメソッドがあることがすぐにわかります
- コードをコピー
- 3. 概要
- 1. プロキシ モードとアダプターの違いモード、ファサード モード、装飾モード a. 類似点: すべて内部オブジェクトをカプセル化し、内部オブジェクトのメソッドを呼び出します
- b. 相違点: それぞれに独自の特性とアプリケーション シナリオがあり、相互に置き換えることはできません。したがって、使用する場合は、どれが適しているかを慎重に分析する必要があります。
- 2. パターンの選択について パターンの選択は、ビジネス ロジックの慎重な分析を通じて実際のビジネス ニーズに基づいて行われ、パターンの特性とアプリケーション シナリオに基づいて合理的な選択と差別化が行われる必要があります。パターン。ほとんどの場合、ビジネスを実装するためにどのモデルを選択するかではなく、ビジネス シナリオによって決定されます。いくつかのケースでは実際に問題を解決できるため、重要なのは将来の拡張を考慮することです。
- これまでに 7 つの構造パターンについて学習しました。次の記事では、引き続きデザイン パターンの動作パターンを紹介します。まず、動作パターンの種類をプレビューしてみましょう。
- u テンプレート メソッド パターン u コマンドモード
- u イテレータモード u オブザーバーモード
u メモモード
u インタプリタモードu ステータスモード
u ストラテジーモードu責任連鎖モード
u ビジターモード

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









PHPロギングは、Webアプリケーションの監視とデバッグ、および重要なイベント、エラー、ランタイムの動作をキャプチャするために不可欠です。システムのパフォーマンスに関する貴重な洞察を提供し、問題の特定に役立ち、より速いトラブルシューティングをサポートします

Laravelは、直感的なフラッシュメソッドを使用して、一時的なセッションデータの処理を簡素化します。これは、アプリケーション内に簡単なメッセージ、アラート、または通知を表示するのに最適です。 データは、デフォルトで次の要求のためにのみ持続します。 $リクエスト -

PHPクライアントURL(CURL)拡張機能は、開発者にとって強力なツールであり、リモートサーバーやREST APIとのシームレスな対話を可能にします。尊敬されるマルチプロトコルファイル転送ライブラリであるLibcurlを活用することにより、PHP Curlは効率的なexecuを促進します

Laravelは簡潔なHTTP応答シミュレーション構文を提供し、HTTP相互作用テストを簡素化します。このアプローチは、テストシミュレーションをより直感的にしながら、コード冗長性を大幅に削減します。 基本的な実装は、さまざまな応答タイプのショートカットを提供します。 Illuminate \ support \ facades \ httpを使用します。 http :: fake([[ 'google.com' => 'hello world'、 'github.com' => ['foo' => 'bar']、 'forge.laravel.com' =>

顧客の最も差し迫った問題にリアルタイムでインスタントソリューションを提供したいですか? ライブチャットを使用すると、顧客とのリアルタイムな会話を行い、すぐに問題を解決できます。それはあなたがあなたのカスタムにより速いサービスを提供することを可能にします

記事では、PHP 5.3で導入されたPHPの後期静的結合(LSB)について説明し、より柔軟な継承を求める静的メソッドコールのランタイム解像度を可能にします。 LSBの実用的なアプリケーションと潜在的なパフォーマ

この記事では、フレームワークにカスタム機能を追加し、アーキテクチャの理解、拡張ポイントの識別、統合とデバッグのベストプラクティスに焦点を当てています。
