PHP オブジェクト指向の要点のまとめ_PHP チュートリアル
PHP オブジェクト指向の概要
1 extends を使用して継承、オーバーロード、およびマジック メソッドの意味を実装する
クラス B は A を拡張します
宣言する場合、BはAのメソッドを持つ必要はありません
電話をかける場合:
$b=新しいB();
$b->A の Method();
$b->A=1 の属性;
$b->B の Method();
$b->B の Method();
If $a=new A();
はい
$a->A の Method();
$a->A=1 の属性;
いいえ
$a->B の Method();
$a->B の Method();
オーバーロード: B は A を継承し、B は A と同じ名前のメソッド属性を実装します。
PHP の「オーバーロード」は、他のほとんどのオブジェクト指向言語とは異なります。従来の「オーバーロード」は、同じ名前を持つ複数のクラス メソッドを提供するために使用されますが、各メソッドのパラメーターの型と数は異なります。
マジック メソッド: PHP は、__ (2 つのアンダースコア) で始まるすべてのクラス メソッドをマジック メソッドとして扱います。したがって、独自のクラス メソッドを定義する場合は、先頭に __ を付けないでください。
2 プライベートおよび保護されたアクセス修飾子の可視性を継承します
属性メソッドのプライベートは継承できません
属性メソッドの保護されたクラスは外部からは見えず、継承可能です
パブリック プロパティ メソッドで定義されたクラス メンバーにはどこからでもアクセスできます
3 phpでの二重コロン::の適用
「::」演算子は、PHP クラス コードでよく見られます。これは、二重コロン「::」で表されるスコープ制限演算子で、クラス内のさまざまなスコープのレベルを設定するために使用されます。左側はスコープ、右側はアクセス スコープのメンバーです。
PHP には self とparent という 2 つのスコープが定義されています (静的スコープは PHP6 で提供されます)。
スコープ解決演算子 (Paamayim Nekudotayim とも呼ばれます)、またはもっと単純にコロンのペアを使用して、静的メンバー、メソッド、定数にアクセスできます。また、サブクラスで親クラスのメンバーやメソッドをオーバーライドするために使用することもできます。
コードは次のとおりです:
const CONST_VALUE = '定数値';
}
エコー MyClass::CONST_VALUE;
クラスOtherClassはMyClassを拡張します
{
パブリック静的 $my_static = '静的変数';
パブリック静的関数 doubleColon() {
echoparent::CONST_VALUE "n";
echo self::$my_static . "n";
}
}
OtherClass::doubleColon();
//サブクラスは親クラスをオーバーライドします
クラスMyClass
{
保護された関数 myFunc() {
echo "MyClass::myFunc()n";
}
}
クラスOtherClassはMyClassを拡張します
{
// 親クラスのメソッドをオーバーライドします
パブリック関数 myFunc()
{
//ただし、オーバーライドされたメソッドを呼び出すことはできます
parent::myFunc();
echo "OtherClass::myFunc()n";
}
}
$class = 新しい OtherClass();
$class->myFunc();
4 phpにおけるthis、self、parentの役割
this: これは現在のオブジェクト インスタンスへのポインターであり、他のオブジェクトやクラスを指しません。
self: 現在のクラスのスコープを表します。これとは異なり、Self はクラスの特定のインスタンスを表すものではなく、継承階層内での自身の位置を識別することはできません。つまり、self が拡張クラスで使用される場合、親クラスのメソッドではなく、拡張クラスのオーバーロードされたメソッドが呼び出されます。 self はクラス自体を指します。つまり、self はインスタンス化されたオブジェクトを指しません。一般に、self はクラス内の静的変数を指すために使用されます。
コードは次のとおりです:
プライベート $lastCount;
//コンストラクター
関数__construct()
{
$this->lastCount = ++self:$firstCount; //self を使用して静的変数を呼び出すときは、:: (フィールド操作シンボル) を使用する必要があります。
}
parent: 現在のクラスの親クラスのスコープを示し、それ以外はself属性と同じです。 parent は親クラスへのポインタです。通常、parent を使用して親クラスのコンストラクタを呼び出します。
//継承クラスのコンストラクター
{
parent::__construct( "test" ); //parent を使用して親クラスのコンストラクターを呼び出します
$this->personSex = $personSex;
$this->personAge = $personAge;
}
5 コンストラクターとデストラクター
コンストラクターを持つクラスは、オブジェクトが作成されるたびに最初にこのメソッドを呼び出すため、オブジェクトを使用する前に初期化作業を行うことが非常に適しています。
関数 __construct() {}
コンストラクターがサブクラスで定義されている場合、その親クラスのコンストラクターは暗黙的に呼び出されません。親クラスのコンストラクターを実行するには、子クラスのコンストラクターでparent::__construct()を呼び出す必要があります。
PHP 5 では、C++ などの他のオブジェクト指向言語と同様に、デストラクターの概念が導入されました。デストラクターは、オブジェクトへのすべての参照が削除されるか、オブジェクトが明示的に破棄されるときに実行されます。
関数 __destruct() {}
6 最後のキーワード
PHP 5 では、新しい Final キーワードが追加されています。親クラスのメソッドがfinalと宣言されている場合、サブクラスはそのメソッドをオーバーライドできません。クラスがfinalと宣言されている場合、そのメソッドは継承できません。
7 継承とコンストラクター
親クラス | サブクラス | 結果 |
コンストラクターがあります | コンストラクターなし | 親コンストラクト |
コンストラクターがあります | コンストラクターがあります | 基礎構造 |
8つのインターフェース
標準クラスを定義するのと同じように、interface を通じてインターフェイスを定義できます。
注:
1) ただし、その中で定義されているメソッドはすべて空です。
2) インターフェースで定義されたすべてのメソッドはパブリックである必要があります。これはインターフェースの特性です
3) 複数のインターフェースを実装する場合、インターフェース内のメソッドに同じ名前を付けることはできません。
4) extends 演算子を使用してインターフェイスを継承することもできます。
5) インターフェース内で定数を定義することもできます。インターフェイス定数とクラス定数はまったく同じように使用されます。 これらはすべて固定値であり、サブクラスやサブインターフェイスによって変更することはできません。
インターフェイス iTemplate
{
パブリック関数 setVariable($name, $var);}
// インターフェースを実装します
//以下の書き方が正しいです
クラス Template は iTemplate を実装します
{
プライベート $vars = array();
パブリック関数 setVariable($name, $var)
{
$this->vars[$name] = $var;
}
パブリック関数 getHtml($template)
{
foreach($this->vars as $name =>$value) {
$template = str_replace('{' . $name . '}', $value, $template);
}
return $template;
}
}
9 物件
クラスの変数メンバーは「プロパティ」と呼ばれます。プロパティ宣言はキーワード public 、 protected 、または private で始まり、その後に変数が続きます。 属性内の変数は初期化できますが、初期化される値は定数である必要があります。ここでの定数は、コンパイル段階後の実行段階で計算される定数ではなく、PHP スクリプトがコンパイル段階にある定数を指します。
PHP5では
を取得するための2つの関数「__get()」と「__set()」があらかじめ定義されています。 属性を取得して割り当てます。また、属性を確認するには「__isset()」、属性を削除するには「__unset()」を使用します。
簡単に言うと、1 つは値を取得するためのもので、もう 1 つは値を代入するためのものです。 2 つのメソッド「__set()」と「__get()」、これら 2 つのメソッドはデフォルトでは存在しませんが、コンストラクター メソッド (__construct()) と同様に手動でクラスに追加されます。もちろん、これら 2 つのメソッドは、個人のスタイルに応じて追加することもできます: //__get() メソッドはプライベート属性を取得するために使用されます
クラス人{ //以下は人々のメンバー属性です
private $sex //人の性別
private $age //人の年齢
//__get() メソッドはプライベート属性を取得するために使用されます
プライベート関数 __get($property_name){
if(isset($this->$property_name)){
return($this->$property_name);}else {
リターン(NULL); }
}
}
//__set() メソッドはプライベート属性を設定するために使用されます
プライベート関数 __set($property_name, $value){
$this->$property_name = $value; }
//__isset() メソッド
プライベート関数 __isset($nm){
echo "isset() 関数がプライベート メンバーを決定すると、自動的に呼び出されます
"; return isset($this->$nm); }
//__unset() メソッド
プライベート関数 __unset($nm){
echo "プライベートメンバーを削除するためにクラス外で unset() 関数が使用されると自動的に呼び出されます
"; unset($this->$nm); }
}
$p1=新しい人
; $p1->name="これは人の名前です"; // isset() 関数を使用してプライベート メンバーを測定する場合、完了を支援するために __isset() メソッドが自動的に呼び出され、戻り結果は true になります
echo var_dump(isset($p1->name))."
"; echo $p1->name."
"; // unset() 関数を使用してプライベート メンバーを削除すると、__unset() メソッドが自動的に呼び出され、タスクを完了して name private 属性を削除できるようになります
unset($p1->名前); //削除されたため、この行の出力はありません
エコー $p1->名前
?>
コードは次のとおりです:
//人のメンバー属性は以下の通りです
プライベート $name;
//人の名前
プライベート$セックス;
//人の性別
プライベート $age;
//人の年齢
//__get() メソッドはプライベート属性を取得するために使用されます
プライベート関数 __get($property_name){
if(isset($this->$property_name)){
return($this->$property_name);
}その他{
return(NULL);
}
}
}
//__set() メソッドはプライベート属性の設定に使用されます
プライベート関数 __set($property_name, $value){
$this->$property_name = $value;
}
//__isset() メソッド
プライベート関数 __isset($nm){
echo "isset() 関数がプライベート メンバーを決定すると、自動的に呼び出されます
";
return isset($this->$nm);
}
//__unset() メソッド
プライベート関数 __unset($nm){
echo "プライベートメンバーを削除するためにクラス外で unset() 関数が使用されると自動的に呼び出されます
";
unset($this->$nm);
}
}
$p1=新しい人
; $p1->name="これは人の名前です";
// isset() 関数を使用してプライベート メンバーを測定する場合、完了を支援するために __isset() メソッドが自動的に呼び出され、戻り結果は true になります
echo var_dump(isset($p1->name))."
";
echo $p1->name."
";
// unset() 関数を使用してプライベート メンバーを削除すると、__unset() メソッドが自動的に呼び出され、タスクを完了して名前プライベート属性を削除できるようになります
unset($p1->名前);
//削除されたため、この行の出力はありません
エコー $p1->名前
?>
クローン10個
オブジェクトのコピーは、 clone キーワードを通じて実行できます (オブジェクトに __clone() メソッドが存在する場合、それが最初に呼び出されます)。オブジェクト内の __clone() メソッドを直接呼び出すことはできません。
オブジェクトがコピーされると、PHP5 はオブジェクトのすべてのプロパティの「浅いコピー」を実行します。プロパティ内のすべての参照は変更されず、元の変数を指します。 __clone() メソッドが定義されている場合、新しく作成されたオブジェクト (コピーによって生成されたオブジェクト) の __clone() メソッドが呼び出され、(必要に応じて) 属性の値を変更するために使用できます。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

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

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

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

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

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

ホットトピック











PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

あなたが経験豊富な PHP 開発者であれば、すでにそこにいて、すでにそれを行っていると感じているかもしれません。あなたは、運用を達成するために、かなりの数のアプリケーションを開発し、数百万行のコードをデバッグし、大量のスクリプトを微調整してきました。

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

JWTは、JSONに基づくオープン標準であり、主にアイデンティティ認証と情報交換のために、当事者間で情報を安全に送信するために使用されます。 1。JWTは、ヘッダー、ペイロード、署名の3つの部分で構成されています。 2。JWTの実用的な原則には、JWTの生成、JWTの検証、ペイロードの解析という3つのステップが含まれます。 3. PHPでの認証にJWTを使用する場合、JWTを生成および検証でき、ユーザーの役割と許可情報を高度な使用に含めることができます。 4.一般的なエラーには、署名検証障害、トークンの有効期限、およびペイロードが大きくなります。デバッグスキルには、デバッグツールの使用とロギングが含まれます。 5.パフォーマンスの最適化とベストプラクティスには、適切な署名アルゴリズムの使用、有効期間を合理的に設定することが含まれます。

文字列は、文字、数字、シンボルを含む一連の文字です。このチュートリアルでは、さまざまな方法を使用してPHPの特定の文字列内の母音の数を計算する方法を学びます。英語の母音は、a、e、i、o、u、そしてそれらは大文字または小文字である可能性があります。 母音とは何ですか? 母音は、特定の発音を表すアルファベットのある文字です。大文字と小文字など、英語には5つの母音があります。 a、e、i、o、u 例1 入力:string = "tutorialspoint" 出力:6 説明する 文字列「TutorialSpoint」の母音は、u、o、i、a、o、iです。合計で6元があります

このチュートリアルでは、PHPを使用してXMLドキュメントを効率的に処理する方法を示しています。 XML(拡張可能なマークアップ言語)は、人間の読みやすさとマシン解析の両方に合わせて設計された多用途のテキストベースのマークアップ言語です。一般的にデータストレージに使用されます

静的結合(静的::) PHPで後期静的結合(LSB)を実装し、クラスを定義するのではなく、静的コンテキストで呼び出しクラスを参照できるようにします。 1)解析プロセスは実行時に実行されます。2)継承関係のコールクラスを検索します。3)パフォーマンスオーバーヘッドをもたらす可能性があります。

PHPの魔法の方法は何ですか? PHPの魔法の方法には次のものが含まれます。1。\ _ \ _コンストラクト、オブジェクトの初期化に使用されます。 2。\ _ \ _リソースのクリーンアップに使用される破壊。 3。\ _ \ _呼び出し、存在しないメソッド呼び出しを処理します。 4。\ _ \ _ get、dynamic属性アクセスを実装します。 5。\ _ \ _セット、動的属性設定を実装します。これらの方法は、特定の状況で自動的に呼び出され、コードの柔軟性と効率を向上させます。
