検索
ホームページバックエンド開発PHPチュートリアルPHP オブジェクト指向の要点のまとめ_PHP チュートリアル

PHP オブジェクト指向の要点のまとめ_PHP チュートリアル

Jul 13, 2016 am 10:14 AM
extendsphp使用成し遂げる物体要約する継承する過負荷のために魔法

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 とも呼ばれます)、またはもっと単純にコロンのペアを使用して、静的メンバー、メソッド、定数にアクセスできます。また、サブクラスで親クラスのメンバーやメソッドをオーバーライドするために使用することもできます。

コードは次のとおりです:

クラスMyClass {
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 はクラス内の静的変数を指すために使用されます。

コードは次のとおりです:

プライベート静的 $firstCount = 0;
プライベート $lastCount;

//コンストラクター
関数__construct()
{
$this->lastCount = ++self:$firstCount; //self を使用して静的変数を呼び出すときは、:: (フィールド操作シンボル) を使用する必要があります。 }

parent: 現在のクラスの親クラスのスコープを示し、それ以外はself属性と同じです。 parent は親クラスへのポインタです。通常、parent を使用して親クラスのコンストラクタを呼び出します。

コードは次のとおりです:

//継承クラスのコンストラクター
function __construct( $personSex, $personAge )
{
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」インターフェースを宣言します

インターフェイス iTemplate

{

パブリック関数 setVariable($name, $var);
パブリック関数 getHtml($template);
}
// インターフェースを実装します
//以下の書き方が正しいです
クラス 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 $name //人の名前
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() メソッドが呼び出され、(必要に応じて) 属性の値を変更するために使用できます。

www.bkjia.comtru​​ehttp://www.bkjia.com/PHPjc/907713.html技術記事 PHP オブジェクト指向の要点のまとめ 1 extends を使用して、継承、オーバーロード、およびマジック メソッドの意味を実装します。クラス B は A を拡張します。宣言する場合、B は A にメソッドを持つ必要はありません。呼び出し時: $b=new.. .
声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
誇大広告を超えて:今日のPHPの役割の評価誇大広告を超えて:今日のPHPの役割の評価Apr 12, 2025 am 12:17 AM

PHPは、特にWeb開発の分野で、最新のプログラミングで強力で広く使用されているツールのままです。 1)PHPは使いやすく、データベースとシームレスに統合されており、多くの開発者にとって最初の選択肢です。 2)動的コンテンツ生成とオブジェクト指向プログラミングをサポートし、Webサイトを迅速に作成および保守するのに適しています。 3)PHPのパフォーマンスは、データベースクエリをキャッシュおよび最適化することで改善でき、その広範なコミュニティと豊富なエコシステムにより、今日のテクノロジースタックでは依然として重要になります。

PHPの弱い参照は何ですか、そしていつ有用ですか?PHPの弱い参照は何ですか、そしていつ有用ですか?Apr 12, 2025 am 12:13 AM

PHPでは、弱い参照クラスを通じて弱い参照が実装され、ガベージコレクターがオブジェクトの回収を妨げません。弱い参照は、キャッシュシステムやイベントリスナーなどのシナリオに適しています。オブジェクトの生存を保証することはできず、ごみ収集が遅れる可能性があることに注意する必要があります。

PHPで__invoke Magicメソッドを説明してください。PHPで__invoke Magicメソッドを説明してください。Apr 12, 2025 am 12:07 AM

\ _ \ _ Invokeメソッドを使用すると、オブジェクトを関数のように呼び出すことができます。 1。オブジェクトを呼び出すことができるように\ _ \ _呼び出しメソッドを定義します。 2。$ obj(...)構文を使用すると、PHPは\ _ \ _ Invokeメソッドを実行します。 3。ロギングや計算機、コードの柔軟性の向上、読みやすさなどのシナリオに適しています。

同時性については、PHP 8.1の繊維を説明します。同時性については、PHP 8.1の繊維を説明します。Apr 12, 2025 am 12:05 AM

繊維はPhp8.1で導入され、同時処理機能が改善されました。 1)繊維は、コルーチンと同様の軽量の並行性モデルです。 2)開発者がタスクの実行フローを手動で制御できるようにし、I/O集約型タスクの処理に適しています。 3)繊維を使用すると、より効率的で応答性の高いコードを書き込むことができます。

PHPコミュニティ:リソース、サポート、開発PHPコミュニティ:リソース、サポート、開発Apr 12, 2025 am 12:04 AM

PHPコミュニティは、開発者の成長を支援するための豊富なリソースとサポートを提供します。 1)リソースには、公式のドキュメント、チュートリアル、ブログ、LaravelやSymfonyなどのオープンソースプロジェクトが含まれます。 2)StackOverFlow、Reddit、およびSlackチャネルを通じてサポートを取得できます。 3)開発動向は、RFCに従うことで学ぶことができます。 4)コミュニティへの統合は、積極的な参加、コード共有への貢献、および学習共有への貢献を通じて達成できます。

PHP対Python:違いを理解しますPHP対Python:違いを理解しますApr 11, 2025 am 12:15 AM

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHPは、シンプルな構文と高い実行効率を備えたWeb開発に適しています。 2。Pythonは、簡潔な構文とリッチライブラリを備えたデータサイエンスと機械学習に適しています。

PHP:それは死にかけていますか、それとも単に適応していますか?PHP:それは死にかけていますか、それとも単に適応していますか?Apr 11, 2025 am 12:13 AM

PHPは死にかけていませんが、常に適応して進化しています。 1)PHPは、1994年以来、新しいテクノロジーの傾向に適応するために複数のバージョンの反復を受けています。 2)現在、電子商取引、コンテンツ管理システム、その他の分野で広く使用されています。 3)PHP8は、パフォーマンスと近代化を改善するために、JITコンパイラおよびその他の機能を導入します。 4)Opcacheを使用してPSR-12標準に従って、パフォーマンスとコードの品質を最適化します。

PHPの未来:適応と革新PHPの未来:適応と革新Apr 11, 2025 am 12:01 AM

PHPの将来は、新しいテクノロジーの傾向に適応し、革新的な機能を導入することで達成されます。1)クラウドコンピューティング、コンテナ化、マイクロサービスアーキテクチャに適応し、DockerとKubernetesをサポートします。 2)パフォーマンスとデータ処理の効率を改善するために、JITコンパイラと列挙タイプを導入します。 3)パフォーマンスを継続的に最適化し、ベストプラクティスを促進します。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

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

ホットツール

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

SublimeText3 中国語版

SublimeText3 中国語版

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