ThinkPHP のクラスのコンストラクター _construct() と _initialize() の違いの詳細な紹介
この記事では主に ThinkPHP のクラスの constructor_construct() と _initialize() の違いについて詳しく紹介していますので、必要な方はぜひご覧ください。 。 バー。
前書き
THINKPHP に精通している PHP 者は基本的に _initialize()
メソッドに精通していると思いますが、 _construct()
を使用することはほとんどないようです。 > プラグインを自分で作成しない限り、使用されることはほとんどありません。 _initialize()
这个方法,我们似乎也很少去使用_construct()
,除非自己写插件,否则还真是很少用到。
今天查看代码突然看到_construct()
这个php自带的构造方法,我的第一感觉是比较陌生,虽然之前学习java时经常遇到,但是很久不用基本忘记。我平时的习惯是将知识的重点写
在我那本小笔记上,但是很久不写字,曾经高中那个那种飘逸灵动的书写笔法彻底丢到异次元。再加上之前的想法,所以就来学习学习技术大牛们写写博客,这不是为了装逼,而只是让自己工作成果的点点滴滴都能不随时间流逝而消散。下面来看看详细的介绍吧。
先贴上代码(我的环境是wamp,使用了TP框架):
创建的FatherAction.class.php文件
<?php class FatherAction extends Action{ public function construct(){ echo 'father'; } } ?>
创建的SonAction.class.php文件
<?php class SonAction extends FatherAction{ public function construct(){ echo 'son'; } function index(){ } } ?>
运行子类SonAction里的index()
可以看到输出的结果:
son
如果将子类改为:
<?php class SonAction extends FatherAction{ public function construct(){ parent::construct(); echo 'son'; } function index(){ } } ?>
运行结果为;
fatherson
上面的结果可以得出结论:
在执行子类的构造函数时并不会自动调用父类的构造函数,如果你要调用的话,那么要加上parent::construct()
当我们把上述的构造方法改为THINKPHP_initialize()
方法时运行会发现:结果与前面的一致,若要执行父类的_initialize()
方法,也需要使用这一句:parent::_initialize()
那是不是说明php自带的构造函数construct()
与THINKPHP的_initialize()
方法一样的呢?
先贴上两段代码:
<?php class FatherAction extends Action{ public function construct(){ echo 'father'; } } ?>
<?php class SonAction extends FatherAction{ public function _initialize(){ echo 'son'; } function index(){ } } ?>
当执行子类SonAction的index方法时发现,输出的结果为:father
即子类调用了父类的构造函数,而没有调用子类的_initialize()
方法
再贴上两段代码:
<?php class FatherAction extends Action{ public function construct(){ if(method_exists($this,"hello")){ $this->hello(); } echo 'father'; } } ?>
<?php class SonAction extends FatherAction{ public function _initialize(){ echo 'son'; } function index(){ } function hello(){ echo 'hello'; } } ?>
执行子类SonAction的index方法,发现输入的结果为hellofather
由此可以得出结论:
当THINKPHP的父类有构造函数而子类没有时,THINKPHP不会去执行子类的_initialize()
;
当THINKPHP的父类子类均有构造函数时,要调用父类的构造函数必须使用parent::construct()
----------------- _initialize()
同理;
当THINKPHP的子类同时存在construct
构造函数和_initialize()
方法,只会执行子类的construct
、最初に感じたことは、比較的馴染みのないもので、以前 Java を勉強していたときによく目にしたものの、時間が経つと基本的に忘れてしまっていました。私のいつもの習慣は、小さなノートに知識の要点を書き留めることですが、長い間書いていなかったので、高校時代のエレガントでスマートな文体は完全に別次元に消えていました。これまでの考えに加えて、私はテクノロジーの専門家からブログの書き方を学ぶようになりました。これは自慢するためではなく、単に私の仕事の結果が時間の経過とともに消えてしまうのを防ぐためです。詳しい紹介を見てみましょう。 まずコードを貼り付けます(私の環境はTPフレームワークを使用したwampです):
🎜🎜🎜🎜FatherAction.class.phpファイルを作成しました🎜🎜rrreee🎜🎜SonAction.class.phpファイルを作成しました🎜🎜rrreee 🎜Run index() を実行すると、出力結果が表示されます: 🎜rrreee🎜🎜 サブクラスを次のように変更すると: 🎜🎜rrreee🎜🎜 実行結果は次のようになります: 🎜🎜rrreee🎜🎜🎜 上記結果は次のように結論付けることができます: 🎜🎜🎜🎜 サブクラスのコンストラクターを実行するときに、親クラスのコンストラクターは自動的に呼び出されません。呼び出したい場合は、parent::construct()
を追加します。 🎜🎜上記の構築メソッドを THINKPHP_initialize()
メソッドに変更すると、親クラスの _initialize() を実行する場合、結果が以前のメソッドと一致していることがわかります。 メソッドでは、次の文も使用する必要があります: <code>parent::_initialize()
🎜🎜これは、PHP 独自のコンストラクター construct()
が THINKPHP のコンストラクターとは異なることを意味しますか? _initialize()メソッドは同じですか? 🎜🎜🎜最初に2つのコードを貼り付けます:🎜🎜rrreeerrreee🎜サブクラスSonActionのindexメソッドを実行すると、出力結果は次のようになります: Father🎜🎜 つまり、サブクラスは親クラスのコンストラクターを呼び出しますが、 _initialize()
メソッド 🎜🎜🎜 を作成し、次の 2 つのコードを貼り付けます: 🎜🎜rrreeerrreee🎜 サブクラス SonAction のインデックス メソッドを実行し、入力結果が hellofather🎜🎜🎜これから結論を導き出すことができます: 🎜🎜🎜🎜 THINKPHP の親クラスにコンストラクターがあるが、サブクラスにはコンストラクターがない場合、THINKPHP はサブクラスの _initialize()
を実行しません。 >; 🎜🎜 場合 THINKPHP の親クラスとサブクラスがすべてコンストラクターを持つ場合、 parent::construct()
---------------- を使用する必要があります。親クラスのコンストラクターを呼び出す - _initialize()
THINKPHP のサブクラスに construct
コンストラクターと _initialize() の両方がある場合も同様です。
メソッドでは、サブクラスのみが実行されます。クラスの construct
コンストラクター (私はこれを個人的にテストしましたが、上記のコードにはありません)。 🎜🎜🎜🎜概要🎜🎜🎜以上がThinkPHP のクラスのコンストラクター _construct() と _initialize() の違いの詳細な紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホット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)

ホットトピック









ThinkPHP プロジェクトを実行するには、Composer をインストールし、Composer を使用してプロジェクトを作成し、プロジェクト ディレクトリに入り、php bin/consoleserve を実行し、http://localhost:8000 にアクセスしてようこそページを表示する必要があります。

ThinkPHP には、さまざまな PHP バージョン向けに設計された複数のバージョンがあります。メジャー バージョンには 3.2、5.0、5.1、および 6.0 が含まれますが、マイナー バージョンはバグを修正し、新機能を提供するために使用されます。最新の安定バージョンは ThinkPHP 6.0.16 です。バージョンを選択するときは、PHP バージョン、機能要件、コミュニティ サポートを考慮してください。最高のパフォーマンスとサポートを得るには、最新の安定バージョンを使用することをお勧めします。

ThinkPHP フレームワークをローカルで実行する手順: ThinkPHP フレームワークをローカル ディレクトリにダウンロードして解凍します。 ThinkPHP ルート ディレクトリを指す仮想ホスト (オプション) を作成します。データベース接続パラメータを構成します。 Webサーバーを起動します。 ThinkPHP アプリケーションを初期化します。 ThinkPHP アプリケーションの URL にアクセスして実行します。

Laravel フレームワークと ThinkPHP フレームワークのパフォーマンスの比較: ThinkPHP は、最適化とキャッシュに重点を置いて、一般に Laravel よりもパフォーマンスが優れています。 Laravel は優れたパフォーマンスを発揮しますが、複雑なアプリケーションの場合は、ThinkPHP の方が適している可能性があります。

ThinkPHP のインストール手順: PHP、Composer、および MySQL 環境を準備します。 Composer を使用してプロジェクトを作成します。 ThinkPHP フレームワークと依存関係をインストールします。データベース接続を構成します。アプリケーションコードを生成します。アプリケーションを起動し、http://localhost:8000 にアクセスします。

「開発に関する提案: ThinkPHP フレームワークを使用して非同期タスクを実装する方法」 インターネット技術の急速な発展に伴い、Web アプリケーションには、多数の同時リクエストと複雑なビジネス ロジックを処理するための要件がますます高まっています。システムのパフォーマンスとユーザー エクスペリエンスを向上させるために、開発者は多くの場合、電子メールの送信、ファイルのアップロードの処理、レポートの生成など、時間のかかる操作を実行するために非同期タスクの使用を検討します。 PHP の分野では、人気のある開発フレームワークとして ThinkPHP フレームワークが、非同期タスクを実装するための便利な方法をいくつか提供しています。

ThinkPHP は、キャッシュ メカニズム、コードの最適化、並列処理、データベースの最適化などの利点を備えた高性能 PHP フレームワークです。公式パフォーマンステストでは、1秒あたり10,000以上のリクエストを処理できることが示されており、実際のアプリケーションではJD.comやCtripなどの大規模なWebサイトやエンタープライズシステムで広く使用されています。

ThinkPHP6 と Swoole をベースとした RPC サービスがファイル転送機能を実装 はじめに: インターネットの発展に伴い、ファイル転送は私たちの日常業務においてますます重要になってきています。この記事では、ファイル転送の効率化とセキュリティを向上させるために、ThinkPHP6とSwooleをベースとしたファイル転送機能を実現するRPCサービスの具体的な実装方法を紹介します。 WebフレームワークとしてThinkPHP6を使用し、SwooleのRPC機能を利用してサーバー間のファイル転送を実現します。 1. 環境基準
