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

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

WBOY
WBOYオリジナル
2016-07-13 10:14:46710ブラウズ

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 までご連絡ください。