ホームページ  >  記事  >  バックエンド開発  >  PHP におけるオブジェクト指向についての私の理解を話す

PHP におけるオブジェクト指向についての私の理解を話す

零下一度
零下一度オリジナル
2017-07-17 11:29:075517ブラウズ

今日は、PHP のオブジェクト指向の性質について紹介したいと思います。オブジェクト指向と言えば、プロセス指向についても触れなければなりません。私が最初に学んだとき、オブジェクト指向とプロセス指向の区別がつかないことがよくありました。

オブジェクト指向プログラミング (OOP) は、私たちの基本的なスキルです。 PHP5 は OOP を適切にサポートするプログラミングを提供します。 OOP のアイデアを使用して PHP の高度なプログラミングを実行する方法は、PHP プログラミング能力を向上させ、優れた Web 開発アーキテクチャを計画するために非常に意味があります。以下では、例を使用して、PHP の OOP をプログラミングに使用する実際的な意義と応用方法を説明します。

通常、データベース バックエンドを使用して Web サイトを構築するとき、プログラムはさまざまなアプリケーション環境に適している必要があると考えます。他のプログラミング言語と異なるのは、PHP ではデータベースが一連の特定の関数によって操作されることです (ODBC インターフェイスを使用しない場合)。これは非常に効率的ですが、カプセル化だけでは十分ではありません。統一されたデータベース インターフェイスがあれば、プログラムに変更を加えることなく、それをさまざまなデータベースに適用できるため、プログラムの移植性とクロスプラットフォーム機能が大幅に向上します。

それらの違いを紹介しましょう:

オブジェクト指向は、どのオブジェクトが問題を処理するかに焦点を当てます。

最大の特徴は、属性と関数を持ったクラスで構成され、クラスからオブジェクトを取得して問題を解決することです。

プロセス指向は、問題を解決するプロセスに焦点を当てます。この問題を一連のプロセスで一つ一つ解決していくのが最大の特徴です。

1. オブジェクト指向の基本

オブジェクト指向

1. クラスとは何ですか?
同じ属性 (特性) とメソッド (動作) を持つ一連の個体の集合。クラスは抽象的な概念です。

2. オブジェクトとは何ですか?
クラスから取得した特定の属性値を持つ個体をオブジェクトと呼びます。対象は特定の個人です。
例: 人間; Zhang San

3. クラスとオブジェクトの関係は何ですか?
クラスはオブジェクトの抽象化です!オブジェクトはクラスを具体化したものです。
クラスは、このタイプのオブジェクトが持つ属性を示すだけですが、特定の値を持つことはできないため、クラスは抽象クラスになります。
オブジェクトは、クラスのすべての属性を割り当てた後に生成される特定の個体です。すべてのオブジェクトは固有です。

II クラスの宣言とインスタンス化

1. クラスの宣言方法:

class クラス名 {

アクセス修飾子 $property [=デフォルト]値];
[アクセス修飾子] function method (){}
}

2. クラス宣言時の注意事項:

①クラス名は英数字とアンダースコアのみで構成でき、数字で始めることはできません。ビッグ キャメル ケース ルールに準拠する必要があります
② クラス名は class で変更する必要があり、クラス名の後に () を含めることはできません
③ 属性にはアクセス修飾子が必要であり、メソッドはアクセス権なしでも構いません。修飾子。

3. インスタンス化されたオブジェクトとオブジェクト属性メソッドの呼び出し:

$object name = new class name ();
//() は、
クラスの外部から属性とメソッドを呼び出すことなく呼び出すことができます。
$Object name-> $Attribute name;
// -> を使用して属性を呼び出す場合、属性名に $ 記号を含めることはできません
クラス内の属性とメソッドを呼び出します:
$これ -> $ 属性名;

Threeコンストラクター

1. コンストラクターとは何ですか?
コンストラクターはクラス内の特別な関数です。 new キーワードを使用してオブジェクトをインスタンス化することは、クラスのコンストラクターを呼び出すことと同じです。

2. コンストラクターの機能は何ですか?
オブジェクトをインスタンス化するときに、オブジェクトのプロパティに初期値を割り当てるために自動的に呼び出され、使用されます。

3. コンストラクターの書き方:
①コンストラクターの名前はクラス
[public] function person($name){
$this -> name = と同じである必要があります。 $name;
}
②マジックメソッド __construct
[public] function __construct($name){
$this -> name = $name;
}
4.コンストラクターに関する事項:
① 最初の書き方では、コンストラクターの名前はクラスと同じでなければなりません! ! ! !
②クラスに手書きのコンストラクターがない場合、システムにはデフォルトで null パラメーターのコンストラクターがあるため、 new Person() を使用できます
パラメーターを含むコンストラクターを作成すると、null はなくなります。パラメーターの構築、つまり new person() は直接使用できません。
person の後の () 内のパラメーター リストはコンストラクターの要件を満たしている必要があります。 ! ! !
③両方のコンストラクターが同時に存在する場合、__constructが使用されます。

5. デストラクター: __destruct():
①デストラクターは、オブジェクトが破棄されて解放される前に自動的に呼び出されます。
②デストラクターは、リソースを解放するためによく使用されます。オブジェクトの使用後にリソースなどを閉じます。
6. マジックメソッド:

PHP は、__ で始まる一連の関数を提供します。これらの関数は、適切なタイミングで自動的に呼び出されます。はマジックと呼ばれます。 マジックはマジック関数と呼ばれます。
例: 新しいオブジェクトが作成されると関数 __construct(){} が自動的に呼び出されます
オブジェクトが破棄されると関数 __destruct(){} が自動的に呼び出されます
マジックに加えてそれが必要ですメソッド、自己定義関数、およびメソッドを __ で始めることはできません。

最後に、一般に、より複雑な関数を持つクラスの場合は、それらを別のクラス ファイルに書き込みます。


クラスファイル名は同じ小文字にする必要があり、「クラス名 lowercase.class.php」の方法を使用します。

このクラスを他のファイルで使用する場合は、include を使用してこの「.class.php」ファイルをインポートできます。


2. カプセル化と継承

1. カプセル化とは何ですか?
アクセス制御を実現するために外部アクセスを必要としないクラス内のプロパティとメソッドをプライベート化するには、アクセス修飾子を使用します。

*注: アクセス制御を実装するためのものであり、アクセスを拒否するものではありません。言い換えれば、属性をプライベート化した後、ユーザーが提供するメソッドを通じて属性を処理できるように、対応するメソッドを提供する必要があります。

2. カプセル化の役割は何ですか?
① ユーザーはクラスが提供できる機能のみに関心があり、関数の実装の詳細は気にしません。 (カプセル化方法)
② ユーザのデータを制御し、不正なデータの設定を防止し、ユーザに返すデータを制御する(属性のカプセル化+set/getメソッド)

3. カプセル化操作を実装しますか?
①メソッドのカプセル化
クラス内でのみ使用され、外部での使用には提供されていない一部のメソッドについては、private を使用してそのようなメソッドをプライベート化できます。

1 private function formatName(){} //这个方法仅仅能在类内部使用$this调用2 function showName(){3 $this -> formatName();4 }

②属性のカプセル化 + set/get メソッド
属性の設定と読み取りを制御するために、属性をプライベート化し、ユーザーが提供する set/get メソッドを介して属性を設定するように要求できます

1 private $age;2 //set方法3 function setAge($age){4 $this->age=$age;5 }6 //get方法7 function getAge(){8 return $this->age;9 }

$Object->getAge();
$Object->setAge(12);

③属性のカプセル化+マジックメソッド

    __get(  ->   __set(, ->= }

$Object->age; / / オブジェクトのプライベート プロパティにアクセスすると、__get() マジック メソッドが自動的に呼び出され、アクセスされたプロパティ名が __get() メソッドに渡されます。 object プライベート属性が使用されると、__set() マジック メソッドが自動的に呼び出され、設定された属性名と属性値が __set() メソッドに渡されます。 $key の値を決定する分岐構造が異なる場合は、異なる操作を実行します。

4. カプセル化のマジックメソッドについて:

①__set($key,$value): 呼び出す際に、メソッドに2つのパラメータを渡します。 : 設定する必要があるプロパティの名前、属性値。

②__get($key,$value): クラスのプライベート属性を読み取るときに自動的に呼び出されます。呼び出し時に、読み取る必要がある属性の名前をメソッドに渡します。
③__isset($) key): isset() を外部で使用します。関数がプライベート プロパティを検出すると自動的に呼び出されます。
>>> デフォルトでは検出されないプライベート プロパティを検出するには、クラスの外で isset(); を使用します。 false
>>>したがって、__isset(); 関数を使用して、自動的に呼び出されたときに内部検出結果を返すことができます。
りー

当外部使用isset($对象名->私有属性);检测时,将自动调用上述__isset()返回的结果!

④__unset($key):外部使用unset()函数删除私有属性时,自动调用;
 1 function __unset($key){ 2 unset($this -> $key); 3 } 
当外部使用unset($对象名->私有属性);删除属性时,自动将属性名传给__unset(),并交由这个魔术方法处理。

 

继承的基础知识:

1、如何实现继承?
给子类使用extends关键字,让子类继承父类;
class Student extends Person{}

2、实现继承的注意事项?
①子类只能继承父类的非私有属性。
②子类继承父类后,相当于将父类的属性和方法copy到子类,可以直接使用$this调用。
③PHP只能单继承,不支持一个类继承多个类。但是一个类进行多层继承。
class Person{}
class Adult extends Person{}
class Student extends Adult{}
//Student 类就同时具有了Adult类和Person类的属性和方法

3、方法覆盖(方法重写)
条件一: 子类继承父类
条件二:子类重写父类已有方法

符合上述两个条件,称为方法覆盖。覆盖之后,子类调用方法,将调用子类自己的方法。
同样,除了方法覆盖,子类也可以具有与父类同名的属性,进行属性覆盖。

如果,子类重写了父类方法,如何在子类中调用父类同名方法?

partent::方法名();
所以,当子类继承父类时,需在子类的构造中的第一步,首先调用父类构造进行复制。

1 function __construct($name,$sex,$school){2 partent::__construct($name,$sex);3 $this -> school = $school;4 }

 

三、PHP关键字

 

1、final
①final修饰类,此类为最终类,不能被继承!
②final修饰方法,此方法为最终方法,不能被重写!
③final不能修饰属性。

2、static
①可以修饰属性和方法,分别称为静态属性和静态方法,也叫类属性,类方法;
②静态属性,静态方法,只能使用类名直接调用。
使用"类名::$静态属性" , "类名::静态方法()"
Person::$sex;   Person::say();
③静态属性和方法,在类装载时就会声明,先于对象产生。
④静态方法中,不能调用非静态属性或方法;
非静态方法,可以调用静态属性和方法。
(因为静态属性和方法在类装载时已经产生,而非静态的属性方法,此时还没有实例化诞生)
⑤在类中,可以使用self关键字,代指本类名。

1 class Person{2 static $sex = "nan";3 function say(){4 echo self::$sex;5 }6 }

⑥静态属性是共享的,也就是new出很多对象,也是共用一个属性。

3、const关键字:
在类中声明常量,不能是define()函数!必须使用const关键字。
与define()声明相似,const关键字声明常量不能带$,必须全部大写!
常量一旦声明,不能改变。调用时与static一样,使用类名调用Person::常量。

4、instanceof操作符:
检测一个对象,是否是某一个类的实例。(包括爹辈,爷爷辈,太爷爷辈……)

$zhangsan instanceof Person;

 

【小总结】几种特殊操作符

.  只能连接字符串; "".""
=> 声明数组时,关联键与值["key"=>"value"]
-> 对象($this new出的对象)调用成员属性,成员方法;
④ :: ①使用parent关键字,调用父类中的同名方法:parent::say();
      ②使用类名(和self)调用类中的静态属性,静态方法,以及常量。


 

四、单例

シングルトン パターンは単形パターンとも呼ばれます。クラスがオブジェクト インスタンスを 1 つだけ持つことができることが保証されています。

実装のポイント:
① コンストラクターはプライベートであり、オブジェクトの作成に new キーワードを使用することはできません。
② オブジェクトを取得する外部メソッドを提供し、メソッド内でオブジェクトが空かどうかを判定します。
空の場合はオブジェクトを作成して返します。空でない場合は直接返します。
③インスタンスオブジェクトの属性とオブジェクトを取得するメソッドは静的である必要があります。
④その後、オブジェクトは私たちが提供する静的メソッドを使用してのみ作成できます。
eg:$s1 = Singleton::getSingle();

 

***关键词:clone与__clone、__antoload()、串行化与反串行化(序列化与反序列化)、类型约束、魔术方法小总结(12个)

 

clone与__clone


1、当使用=讲一个对象,赋值给另一个对象时,赋的实际是对象的地址。
两个对象指向同一地址,所以一个对象改变,另一个也会变化。
eg: $lisi = $zhangsan;
2、如果想要将一个对象完全克隆出另一个对象,两个对象是独立的,互不干扰的,
则需要使用clone关键字;
eg: $lisi = clone $zhangsan; //两个对象互不干扰
3、__clone():
①当使用clone关键字,克隆对象时,自动调用clone函数。
②__clone()函数,类似于克隆时使用的构造函数,可以给新克隆对象赋初值。
③__clone()函数里面的$this指的是新克隆的对象
某些版本中,可以用$that代指被克隆对象,绝大多数版本不支持。
4、__toString()
当使用echo等输出语句,直接打印对象时调用echo $zhangsan;
那么,可以指定__toString()函数返回的字符串;

1 function __toString(){2 return "haha";3 }4 echo $zhangsan; //结果为:haha

5、__call()
调用类中未定义或未公开的方法时,会自动执行__call()方法。
自动执行时,会给__call()方法传递两个参数;
参数一:调用的方法名
参数二:(数组)调用方法的参数列表。

 

__antoload()


①这是唯一一个不在类中使用的魔术方法;
②当实例化一个不存在的类时,自动调用这个魔术方法;
③调用时,会自动给__autoload()传递一个参数:实例化的类名
所以可以使用这个方法实现自动加载文件的功能。

1 function __autoload($className){2 include    "class/".strtolower($className).".class.php";3 }4 $zhangsan=new Person();//本文件内没有Person类,会自动执行__autoload()加载person.class.php文件

 

面向对象串行化与反串行化(序列化与反序列化)


1、串行化:将对象通过一系列操作,转化为一个字符串的过程,称为串行化。

     (对象通过写出描述自己状态的数值来记录自己)

2、反串行化:将串行化后的字符串,再转为对象的过程,称为反串行化;
3、什么时候使用串行化?
①对象需要在网络中传输的时候
② 对象需要在文件或数据库中持久保存的时候
4、怎样实现串行化与反串行化
串行化:  $str=serialize($zhangsan);
反串行化:$duixiang=unserialize($str);
5、__sleep()魔术方法:
①当执行对象串行化的时候,会自动执行__sleep()函数;
②__sleep()函数要求返回一个数组,数组中的值,就是可以串行化的属性;不在数组中的属性,不能被串行化;
function __sleep(){
return array("name","age"); //只有name/age两个属性可以串行化。
}

6、__wakeup()魔术方法
①当反串行化对象时,自动调用__wakeup()方法;
②自动调用时,用于给反串行化产生的新对象属性,进行重新赋值。
 1 function __wakeup(){ 2 $this -> name = "李四"; 3 } 

类型约束


1、类型约束:是指在变量时,加上数据类型,用于约束此变量只能存放对应的数据类型。
(这种操作常见于强类型语言,在PHP中,只能实现数组和对象的类型约束)
2、如果类型约束为某一个类,则本类以及本类的子类对象,都可以通过。
3、在PHP中,类型约束,只能发生在函数的形参中。

1 class Person{}2 class Student extends Person{}3 function func(Person $p){ //约束函数的形参,只接受Person类及Person子类4 echo "1111";5 echo $p -> name;6 }

func(新しい人());
func("111"); ×
; 形式、私たちはそれを「匿名オブジェクト」と呼びます

***基底クラス: 親クラス

*** 派生クラス: サブクラス


マジックメソッドの概要

1. __construct(): オブジェクトの新規作成時に自動的に呼び出されるコンストラクター。 2. __destruct(): デストラクター。オブジェクトが破棄されるときに自動的に呼び出されます。

3. __get(): クラス内のプライベート プロパティにアクセスするときに自動的に呼び出されます。読み取った属性名を渡し、$this->属性名を返す


4. __set(): クラスのプライベート属性に値を代入するときに自動的に呼び出されます。設定する必要がある属性名と属性値を渡します。
5. __isset(): オブジェクトのプライベート属性を検出するために isset() を使用するときに自動的に呼び出されます。検出された属性名を渡し、 isset($this -> 属性名) を返します
6. __unset(): オブジェクトのプライベート属性を削除するために unset() を使用するときに自動的に呼び出されます。削除された属性名を渡し、メソッド内で unset($this -> 属性名) を実行します。 __toString(): echo を使用してオブジェクトを出力するときに自動的に呼び出されます。オブジェクトを出力するときに表示したいコンテンツを返します。戻り値は文字列である必要があります。 __call(): クラス内の未定義または公開されていないメソッドを呼び出すときに自動的に呼び出されます。呼び出される関数名とパラメーター リストの配列を渡します。
9. __clone(): clone キーワードを使用してオブジェクトを複製するときに自動的に呼び出されます。その機能は、新しく複製されたオブジェクトを初期化して値を割り当てることです
10. __sleep(): オブジェクトがシリアル化されるときに自動的に呼び出されます。配列を返します。配列内の値はシリアル化できる属性です。
11. __wakeup(): オブジェクトが逆シリアル化されるときに自動的に呼び出されます。新しく生成されたオブジェクトを逆シリアル化するには、初期化と代入を実行します。 __autoload(): 関数はクラスの外部で宣言する必要があります。未宣言のクラスがインスタンス化されると自動的に呼び出されます。インスタンス化したクラス名を渡すことで、対応するクラスファイルをクラス名を使用して自動的にロードできます。



6. 抽象クラスと抽象メソッド

1. 抽象メソッドとは何ですか?
メソッド本体 {} のないメソッドは、abstract キーワードを使用して変更する必要があります。このようなメソッドは抽象メソッドと呼ばれます。
abstract functionsay(); //抽象メソッド

2. 抽象クラスとは何ですか?
abstract キーワードで変更されたクラスは抽象クラスです。
抽象クラス 人{}

3. 抽象クラスに関する注意事項:
① 抽象クラスには非抽象メソッドを含めることができます。
② 抽象メソッドを含むクラスは抽象クラスでなければなりません。抽象メソッドを含む;
③ 抽象クラスはインスタンス化できません。 (抽象クラスには抽象メソッドが含まれる場合があります。抽象メソッドにはメソッド本体がなく、インスタンス化の呼び出しは無意味です。)
抽象クラスを使用する目的は、インスタンス化を制限することです。 ! !

4. サブクラスが抽象クラスを継承する場合、サブクラスも抽象クラスでない限り、サブクラスは親クラスのすべての抽象メソッドをオーバーライドする必要があります。

5. 抽象クラスを使用する役割は何ですか?
① インスタンス化を制限します。 (抽象クラスは不完全なクラスです。内部の抽象メソッドにはメソッド本体がないため、インスタンス化できません)
② 抽象クラスは、サブクラスの継承の仕様を提供します。 サブクラスが抽象クラスを継承する場合、サブクラスには と が含まれている必要があります。定義された抽象メソッドを抽象クラスに実装します。

5. オブジェクトのシリアル化とマジックメソッド
7. インターフェースとポリモーフィズム


インターフェース


1. インターフェースとは何ですか?
インターフェイスは、インターフェイスを実装するクラスによって実装される必要があるメソッドの組み合わせのセットを提供する仕様です。
インターフェースは、interface キーワードを使用して宣言されます。
interface Inter{}

2、インターフェース内のすべてのメソッドは抽象メソッドである必要があります。
インターフェース内の抽象メソッドは抽象メソッドを必要とせず、抽象メソッドで変更することもできません。

3. インターフェイス内で変数を宣言することはできず、定数のみを使用できます。 ! !

4. インターフェースは、extends キーワードを使用してインターフェースを継承できます。
インターフェイスは、継承インターフェイスを拡張して多重継承を実現します。
interface int1 は Inter,Inter2 を拡張します。{}

5。クラスは、implements キーワードを使用してインターフェースを実装できます。
クラスはインターフェースを実装するために実装を使用し、複数のインターフェースを同時に実装できます。複数のインターフェースはカンマで区切られます。
抽象クラス 人は Inter,Inter2 を実装します。{}
クラスは 1 つ以上のインターフェースを実装します。次に、このクラス、すべてのインターフェイスのすべての抽象メソッドを実装する必要があります。
ただし、このクラスは抽象クラスです。

[インターフェースと抽象クラスの違い]:

① 宣言方法に関して、インターフェースはinterfaceキーワードを使用し、抽象クラスはabstract classを使用します。
②実装・継承に関しては、クラスは抽象クラスを継承するためにextendsを使用し、インターフェースを実装するためにimplementを使用します。
③抽象クラスは単一の方法でのみ継承でき、インターフェースは複数の方法で実装できます。 (インターフェースはインターフェースを拡張)、複数の実装 (クラスはインターフェースを実装)
④抽象クラスは非抽象メソッドを持つことができ、インターフェースは抽象メソッドのみを持つことができ、抽象メソッドは持てません。抽象クラスの抽象メソッドは、abstract キーワードを使用して変更する必要があります。インターフェイスの抽象メソッドは、修飾子を使用して変更できません。
⑤抽象クラスは属性と変数を持つことができるクラスであり、インターフェイスは定数のみを持つことができます。

2 つの ポリモーフィズム

2 つ。 ポリモーフィズム
1. クラスは複数のサブクラスによって継承されます。
このクラスの特定のメソッドが複数のサブクラスで異なる機能を示す場合、この動作をポリモーフィズムと呼びます。

2. ポリモーフィズムを実現するために必要な方法:
① サブクラスは親クラスを継承します。
③ 親クラスの参照はサブクラスのオブジェクトを指します。

以上がPHP におけるオブジェクト指向についての私の理解を話すの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。