目次
PHP、php Magicの一般的なマジックメソッドの関数と使用例
ホームページ バックエンド開発 PHPチュートリアル PHP での一般的なマジック メソッドの関数と使用例、php magic_PHP チュートリアル

PHP での一般的なマジック メソッドの関数と使用例、php magic_PHP チュートリアル

Jul 13, 2016 am 09:48 AM
php 魔法の方法

PHP、php Magicの一般的なマジックメソッドの関数と使用例

概要

オブジェクト指向プログラミングでは、PHP はプログラミングに非常に便利な一連のマジック メソッドを提供します。 PHP のマジック メソッドは通常、__ (2 つのアンダースコア) で始まり、明示的な呼び出しを必要としませんが、特定の条件によってトリガーされます。この記事では、PHP で利用できるマジック メソッドを簡単にまとめます。

始める前に

PHP のマジック メソッドを要約する前に、後の例で使用する 2 つのクラスを定義しましょう:
コードをコピーします コードは次のとおりです:
クラスデバイス{
公開 $name
パブリック $バッテリー
パブリック $data = array(); パブリック $接続

保護された関数 connect() {
$this->connection = 'リソース';
echo $this->name . PHP_EOL;
}

保護された関数切断() {
$this->connection = null;
echo $this->name . PHP_EOL;
}
}

クラスバッテリー{
プライベート $charge = 0;

パブリック関数 setCharge($charge) {
$charge = (int)$charge;
if($charge $charge = 0;
}
elseif($charge > 100) {
$charge = 100;
}
$this->charge = $charge;
}
}
?>

Device クラスには 4 つのメンバー プロパティと 2 つのメンバー メソッドがあります。 Battery クラスには 1 つのメンバー プロパティと 1 つのメンバー メソッドがあります。

コンストラクターとデストラクター

コンストラクターとデストラクターは、それぞれオブジェクトの作成時と破棄時に呼び出されます。オブジェクトが「破棄される」とは、オブジェクトへの参照が存在しないことを意味します。たとえば、オブジェクトを参照する変数が削除 (設定解除) されたり、再割り当てされたり、スクリプトの実行が終了したりすると、デストラクターが呼び出されます。

__construct()

__construct()コンストラクターは、最も一般的に使用される関数です。オブジェクトを作成するときに、コンストラクターで初期化作業を行うことができます。インスタンス化時に対応する数のパラメーターが渡される限り、コンストラクターには任意の数のパラメーターを定義できます。コンストラクターで例外が発生すると、オブジェクトの作成が妨げられます。

コードをコピーします コードは次のとおりです: クラスデバイス{
パブリック関数 __construct(Battery $battery, $name) {
$this->バッテリー = $バッテリー;
$this->name = $name;
$this->connect();
}
}

上記のサンプルコードでは、Deviceクラスのコンストラクターがメンバーのプロパティに値を代入し、connect()メソッドを呼び出しています。


コードをコピーします コードは次のとおりです: コンストラクターをプライベート メソッドとして宣言すると、シンプレックス パターンでよく使用されるクラス外でオブジェクトが作成されるのを防ぎます。

__destruct()

デストラクターは通常、オブジェクトが破棄されるときに呼び出されます。デストラクターはパラメーターを受け取りません。データベース接続を閉じるなど、一部のクリーンアップ作業はデストラクターで実行されることがよくあります。

プロパティのオーバーロード

注意すべき点の 1 つは、PHP での「オーバーロード」は、他のほとんどの言語でのオーバーロードとは同じではありません。ただし、それらはすべて同じ関数を実装しています。

プロパティのオーバーロードに関与する 2 つのマジック メソッドは主にプロパティ アクセスを処理するために使用され、存在しない (またはアクセスできない) プロパティにアクセスしようとしたときに何が起こるかを定義します。

__get()

存在しないプロパティにアクセスしようとすると、魔法のメソッド __get() が呼び出されます。アクセスされた属性の名前を表すパラメーターを受け取り、属性の値を返します。上記の Device クラスには、次のコードに示すように、ここで役割を果たす data 属性があります。
コードをコピーします コードは次のとおりです: クラスデバイス{
パブリック関数 __get($name) {
If(array_key_exists($name, $this->data)) {
return $this->data[$name];
}
null を返す;
}
}

このマジック メソッドの最も一般的な使用法は、「読み取り専用」属性を作成してアクセス制御を拡張することです。上記の Battery クラスには、プライベート属性 $charge があります。__get() マジック メソッドを使用してこの属性を拡張し、クラス外では読み取り可能ですが変更できないようにすることができます。コードは次のとおりです:


コードをコピーします コードは次のとおりです: クラスバッテリー{
プライベート $charge = 0;

パブリック関数 __get($name) {
If(isset($this->$name)) {
return $this->$name;
}
null を返す;
}
}

__set()

__set() マジック メソッドは、アクセスできないプロパティを変更しようとすると呼び出され、プロパティの名前を表すパラメータとプロパティの値を表すパラメータの 2 つを受け取ります。サンプルコードは次のとおりです:


コードをコピーします コードは次のとおりです: クラスデバイス{
パブリック関数 __set($name, $value) {
// プロパティ名を配列キーとして使用します
$this->data[$name] = $value;
}
}

__isset()

__isset() マジック メソッドは、アクセスできないプロパティに対して isset() メソッドが呼び出されたときに呼び出され、プロパティの名前を表すパラメーターを受け取ります。プロパティが存在するかどうかを示すブール値を返す必要があります。コードは次のとおりです:


コードをコピーします コードは次のとおりです: クラスデバイス{
パブリック関数 __isset($name) {
return array_key_exists($name, $this->data);
}
}

__unset()

__unset() マジックメソッドは、アクセスできない属性を破棄するために unset() 関数を呼び出すときに呼び出され、属性の名前を表すパラメーターを受け取ります。

オブジェクトを文字列に変換します

場合によっては、オブジェクトを文字列の形式で表現する必要があります。オブジェクトを直接出力すると、プログラムはエラー メッセージを出力します: PHP キャッチ可能な致命的なエラー: クラス Device のオブジェクトを文字列に変換できませんでした

__toString()

__toString() は、オブジェクトを文字列として使用するときに呼び出されます。パラメータは受け取りません。このメソッドを使用すると、オブジェクトの表現を定義できます。コードは次のとおりです:


コードをコピーします コードは次のとおりです: クラスデバイス{
パブリック関数 __toString() {
$connected = (isset($this->connection)) '接続済み' : '切断済み';
$count = count($this->data);
$this->name . ' は ' . $count 個のメモリ内にあります' 。 }
...
}


__set_state()(PHP 5.1)

静的マジック メソッド __set_state()。このメソッドは、var_export() 関数を使用してオブジェクトを出力するときに呼び出されます。 var_export() 関数は、PHP 変数を PHP コードに変換するために使用され、オブジェクトの属性値をパラメータとして含む連想配列を受け取ります。サンプルコードは次のとおりです:


コードをコピーします コードは次のとおりです: クラスバッテリー{ //...
パブリック静的関数 __set_state(array $array) {
$obj = 新しい自分();
$obj->setCharge($array['charge']);
戻り $obj;
}
//...
}


オブジェクトのクローン

デフォルトでは、オブジェクトは参照によって渡されます。したがって、オブジェクトを別の変数に割り当てるときは、オブジェクトへの参照が作成されるだけであり、オブジェクトはコピーされません。実際にオブジェクトをコピーするには、clone キーワードを使用する必要があります。
この「参照渡し」戦略は、オブジェクト内に含まれるオブジェクトにも適用されます。オブジェクトを複製しても、そのオブジェクト内のオブジェクトは複製されないため、最終的には両方のオブジェクトが同じ内部オブジェクトを共有することになります。サンプルコードは次のとおりです:
コードをコピーします コードは次のとおりです:
$device = 新しいデバイス(新しいバッテリー(), 'iMagic');
$device2 = $device のクローンを作成します;

$device->battery->setCharge(65);
echo $device2->battery->charge;
// 65

__クローン()

__clone() マジックメソッド __clone() は上記の問題を解決できます。このマジック メソッドは、オブジェクトに対して clone キーワードが使用されるときに呼び出されます。この魔法のメソッドでは、任意のサブオブジェクトをクローンできます。コードは次のとおりです。
コードをコピーします コードは次のとおりです: クラスデバイス{
...
パブリック関数 __clone() {
// Battery オブジェクトをコピーします
$this->battery = クローン $this->battery;
}
...
}

オブジェクトのシリアル化

シリアル化は、任意のデータを文字列形式に変換するプロセスです。シリアル化は通常、オブジェクト全体をデータベースに保存するか、ファイルに書き込むために使用されます。保存されたデータを逆シリアル化する場合、シリアル化する前にオブジェクトを取得できます。ただし、データベース接続など、すべてのデータをシリアル化できるわけではありません。幸いなことに、この問題を解決するための魔法のトリックがあります。

__睡眠()

オブジェクトをシリアル化するとき (serialize() を呼び出すとき)、マジック メソッド __sleep() が呼び出されます。パラメーターは取らず、シリアル化する必要があるすべてのプロパティを含む配列を返す必要があります。このマジック メソッド内では、他の操作も実行できます。

注意すべき点は、実行中のオブジェクトに影響を与える可能性があるため、この関数では破棄操作を実行しないでください。

サンプルコードは次のとおりです:


コードをコピーします コードは次のとおりです: クラスデバイス{
公開 $name
パブリック $バッテリー
パブリック $data = array();
パブリック $接続
//...
パブリック関数 __sleep() {
戻り配列('名前', 'バッテリー', 'データ');
}
//...
}

__ウェイクアップ()

保存されたオブジェクトを逆シリアル化するときに、マジック メソッド __wakeup() が呼び出されます。パラメータを受け取らず、値も返しません。これを使用して、シリアル化中に失われたデータベース接続またはリソースを処理できます。コードは次のとおりです:


コードをコピーします コードは次のとおりです: クラスデバイス{
//...
パブリック関数 __wakeup() {
// ネットワークに再接続します
$this->connect();
}
//...
}

メソッドのオーバーロード

PHP には、メンバー メソッドに関連する 2 つのマジック メソッド __call() と __callStatic() もあります。これらの 2 つのマジック メソッドは、属性のオーバーロード メソッドに似ています。

__call()

存在しない、またはアクセスできないメソッドを呼び出す場合、マジック メソッド __call() が呼び出されます。これは 2 つのパラメータを受け取ります。1 つは呼び出されるメソッドの名前で、もう 1 つは関数パラメータを含む配列です。このメソッドを使用して、子オブジェクト内の同じ名前の関数を呼び出すことができます。

この例では、関数 call_user_func_array() に注目してください。この関数により、名前付き関数を動的に呼び出すことができます。

サンプルコードは次のとおりです:
コードをコピーします コードは次のとおりです:
クラスデバイス{
//...
パブリック関数 __call($name, $arguments) {
// 子オブジェクトにこのメソッドがあることを確認してください
If(method_exists($this->connection, $name)) {
// 呼び出しを子オブジェクトに転送します
return call_user_func_array(array($this->connection, $name), $arguments);
}
null を返す;
}
//...
}

__callStatic()

マジック メソッド __callStatic() には __call() と同じ機能があります。唯一の違いは、このメソッドが存在しない、またはアクセスできない静的メソッドにアクセスしようとしたときに呼び出されることです。サンプルコードは次のとおりです:
コードをコピーします コードは次のとおりです:
クラスデバイス{
//...
パブリック静的関数 __callStatic($name, $arguments) {
// クラスにこのメソッドがあることを確認してください
If(method_exists('接続', $name)) {
// 静的呼び出しをクラスに転送します
return call_user_func_array(array('Connection', $name), $arguments);
}
null を返す;
}
//...
}

関数としてのオブジェクト

オブジェクトを関数として使用する必要がある場合があります。オブジェクトを関数として使用することは、他の通常の関数を使用することと同じであり、パラメーターを渡すことができます。

__invoke()(PHP 5.3)

オブジェクトを関数として使用しようとすると、マジックメソッド __invoke() が呼び出されます。このメソッドで定義されたパラメータはすべて、関数のパラメータとして使用されます。サンプルコードは次のとおりです:
コードをコピーします コードは次のとおりです:
クラスデバイス{
//...
パブリック関数 __invoke($data) {
echo $data;
}
//...
}
$device = 新しいデバイス(新しいバッテリー(), 'iMagic');
$device('テスト');
// $device->__invoke('test') と同等
// 出力: テスト

その他:__autoload()

__autoload() メソッドは魔法のメソッドではありませんが、このメソッドは非常に便利です。ただし、PHP バージョンの更新により、この関数は推奨されなくなり、spl_auto_register() 関数に置き換えられました。

www.bkjia.com本当http://www.bkjia.com/PHPjc/1024903.html技術記事 PHP における一般的なマジック メソッドの関数と使用例、PHP マジックの概要 オブジェクト指向プログラミングでは、PHP はプログラミングに多くのことを提供する一連のマジック メソッドを提供します...
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホット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ヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

CakePHP プロジェクトの構成 CakePHP プロジェクトの構成 Sep 10, 2024 pm 05:25 PM

この章では、CakePHP の環境変数、一般設定、データベース設定、電子メール設定について理解します。

Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Ubuntu および Debian 用の PHP 8.4 インストールおよびアップグレード ガイド Dec 24, 2024 pm 04:42 PM

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

CakePHP の日付と時刻 CakePHP の日付と時刻 Sep 10, 2024 pm 05:27 PM

Cakephp4 で日付と時刻を操作するには、利用可能な FrozenTime クラスを利用します。

CakePHP データベースの操作 CakePHP データベースの操作 Sep 10, 2024 pm 05:25 PM

CakePHP でデータベースを操作するのは非常に簡単です。この章では、CRUD (作成、読み取り、更新、削除) 操作について理解します。

CakePHP ファイルのアップロード CakePHP ファイルのアップロード Sep 10, 2024 pm 05:27 PM

ファイルのアップロードを行うには、フォーム ヘルパーを使用します。ここではファイルアップロードの例を示します。

CakePHP ルーティング CakePHP ルーティング Sep 10, 2024 pm 05:25 PM

この章では、ルーティングに関連する次のトピックを学習します。

CakePHP について話し合う CakePHP について話し合う Sep 10, 2024 pm 05:28 PM

CakePHP は、PHP 用のオープンソース フレームワークです。これは、アプリケーションの開発、展開、保守をより簡単にすることを目的としています。 CakePHP は、強力かつ理解しやすい MVC のようなアーキテクチャに基づいています。モデル、ビュー、コントローラー

CakePHP バリデータの作成 CakePHP バリデータの作成 Sep 10, 2024 pm 05:26 PM

Validator は、コントローラーに次の 2 行を追加することで作成できます。

See all articles