この記事の例では、PHP オブジェクト指向プログラミングの高度な機能について説明します。参考のために皆さんと共有してください。詳細は次のとおりです:
静的プロパティ
<?php class StaticExample { static public $aNum = 0; // 静态共有属性 static public function sayHello() { // 静态共有方法 print "hello"; } } print StaticExample::$aNum; StaticExample::sayHello(); ?>
出力: 0 Hello
コメント: 静的プロパティとメソッドは、クラスを通じて直接呼び出すことができます。
SELF
<?php class StaticExample { static public $aNum = 0; static public function sayHello() { // 这里的static 和 public的顺序可以颠倒 self::$aNum++; print "hello (".self::$aNum.")\n"; // self 指向当前类, $this指向当前对象。 } } StaticExample::sayHello(); StaticExample::sayHello(); StaticExample::sayHello(); ?>
出力:
hello (1) hello (2) hello (3)
コメント: self は現在のクラスを指し、this は現在のオブジェクトを指します。 self は、現在のクラスの静的プロパティとメソッドを呼び出すことができます。これは現在のオブジェクトを指します。 self は、現在のクラスの静的プロパティとメソッドを呼び出すことができます。これにより、現在のクラスの通常のプロパティとメソッドを呼び出すことができます。
定数属性
<?php interface Chargeable { // 接口,抽象类是介于基类与接口之间的东西 public function getPrice(); } class ShopProduct implements Chargeable { // ... protected $price; // ... public function getPrice() { return $this->price; } // ... } $product = new ShopProduct(); ?>
getPriceメソッドが実装されていない場合、エラーが報告されます。
致命的なエラー: クラス ShopProduct には 1 つの抽象メソッドが含まれているため、抽象として宣言するか、残りのメソッド (Chargeable::getPrice) を実装する必要があります
継承されたクラスとインターフェイス
<?php class TimedService{ } interface Bookable{ } interface Chargeable{ } class Consultancy extends TimedService implements Bookable, Chargeable { // 继承类与接口 // ... } ?>
抽象クラス
最初にコードを見てみましょう
<?php abstract class DomainObject { } class User extends DomainObject { public static function create() { return new User(); } } class Document extends DomainObject { public static function create() { return new Document(); } } $document = Document::create(); print_r( $document ); ?>
出力:
Document Object ( )
静的メソッド
<?php abstract class DomainObject { private $group; // 私有属性group public function __construct() { $this->group = static::getGroup();//static 静态类 } public static function create() { return new static(); } static function getGroup() { // 静态方法 return "default"; } } class User extends DomainObject { } class Document extends DomainObject { static function getGroup() { // 改变了内容 return "document"; } } class SpreadSheet extends Document { // 继承之后,group也就与document相同了 } print_r(User::create()); print_r(SpreadSheet::create()); ?>
出力:
User Object ( [group:DomainObject:private] => default ) SpreadSheet Object ( [group:DomainObject:private] => document )
finalフィールド
により、クラスは継承できなくなり、あまり使用されなくなります
<?php final class Checkout { // 终止类的继承 // ... } class IllegalCheckout extends Checkout { // ... } $checkout = new Checkout(); ?>
出力:
致命的エラー: クラス IllegalCheckout は最終クラス (Checkout) から継承できない可能性があります
final メソッドをオーバーライドできません
<?php class Checkout { final function totalize() { // calculate bill } } class IllegalCheckout extends Checkout { function totalize() { // 不能重写final方法 // change bill calculation } } $checkout = new Checkout(); ?>
出力:
致命的エラー: Final メソッド Checkout::totalize() をオーバーライドできません
Destructor
<?php class Person { protected $name; private $age; private $id; function __construct( $name, $age ) { $this->name = $name; $this->age = $age; } function setId( $id ) { $this->id = $id; } function __destruct() { // 析构函数 if ( ! empty( $this->id ) ) { // save Person data print "saving person\n"; } if ( empty( $this->id ) ) { // save Person data print "do nothing\n"; } } } $person = new Person( "bob", 44 ); $person->setId( 343 ); $person->setId( '' ); // 最后执行析构函数,使用完之后执行 ?>
出力:
何もしない
__cloneメソッド
クローン作成時に実行
<?php class Person { private $name; private $age; private $id; function __construct( $name, $age ) { $this->name = $name; $this->age = $age; } function setId( $id ) { $this->id = $id; } function __clone() { // 克隆时候执行 $this->id = 0; } } $person = new Person( "bob", 44 ); $person->setId( 343 ); $person2 = clone $person; print_r( $person ); print_r( $person2 ); ?>
出力:
Person Object ( [name:Person:private] => bob [age:Person:private] => 44 [id:Person:private] => 343 ) Person Object ( [name:Person:private] => bob [age:Person:private] => 44 [id:Person:private] => 0 )
別の例を見てください
<?php class Account { // 账户类 public $balance; // 余额 function __construct( $balance ) { $this->balance = $balance; } } class Person { private $name; private $age; private $id; public $account; function __construct( $name, $age, Account $account ) { $this->name = $name; $this->age = $age; $this->account = $account; } function setId( $id ) { $this->id = $id; } function __clone() { $this->id = 0; } } $person = new Person( "bob", 44, new Account( 200 ) ); // 以类对象作为参数 $person->setId( 343 ); $person2 = clone $person; // give $person some money $person->account->balance += 10; // $person2 sees the credit too print $person2->account->balance; // person的属性account也是一个类,他的属性balance的值是210 // output: // 210 ?>
コメント:学習は依然として脳を開くことができます。$person->account->balance という複数の矢印の概念が存在する理由が今日ようやく理解できました。ここでのアカウント属性はオブジェクトです。
__toString
<?php class Person { function getName() { return "Bob"; } function getAge() { return 44; } function __toString() { $desc = $this->getName()." (age "; $desc .= $this->getAge().")"; return $desc; } } $person = new Person(); print $person; // 打印时候集中处理 // Bob (age 44) ?>
コメント: print または echo の場合は有効でなければなりません。print_r はオブジェクトを出力します。
person Object()
この記事が PHP プログラミングの皆様のお役に立てれば幸いです。
PHP オブジェクト指向プログラミングの高度な機能 (インターフェイス、継承、抽象クラス、破棄、クローン作成など) の詳細な説明については、PHP 中国語 Web サイトに注目してください。