「オーバーロード」は、 クラスのポリモーフィズム の実装です。関数のオーバーロードとは、識別子が複数の関数名として使用され、同じ名前の関数が関数のパラメーターの数またはパラメーターの型によって区別できるため、呼び出し時に混乱が生じないことを意味します。この主な利点は、異なるパラメーターのタイプやパラメーターの数に対して複数の関数を作成する必要がないことです。 複数の関数は同じ名前を使用しますが、パラメータリスト、つまりパラメータの数または(および)
データ型は、メソッド名が同じであっても、自動的に異なる可能性があります。パラメータリストに従って呼び出されます。 PHP4 は
オブジェクト指向
の単純な機能の一部のみを実装していますが、PHP5 はオブジェクトをより強力にサポートします。 ポリモーフィック実装の場合、PHP4 はオーバーライドのみをサポートしますが、オーバーロードはサポートしません。ただし、いくつかのトリックを使用して、オーバーロードの実装を「シミュレート」することができます。
PHP5 は上書きとオーバーロードをサポートできますが、オーバーロードの具体的な実装は他の言語とは依然として大きく異なります。
1、PHP4 でのオーバーロードの「シミュレート」
次のコードを試してください:
<?php //根据参数个数选择执行不同的方法(在 PHP4 中模拟"重载"(多态的一种) class Myclass { function Myclass() { $method = "method" . func_num_args(); $this->$method(); } function method1($x) { echo "method1"; } function method2($x, $y) { echo 'method2'; } } //通过在类中的额外的处理,使用这个类对用户是透明的: $obj1 = new Myclass('A'); //将调用 method1 $obj2 = new Myclass('B','C'); //将调用 method2 ?>
の func_num_args() 関数を使用してパラメーターの数を取得し、method1 または method2 メソッドを自動的に実行します。 。関数 func_get_arg(i) と func_get_args() を組み合わせることによって、上の例を改善できます。 2. PHP5 でオーバーロードを使用する
まず次の例を見てください:
コードは次のとおりです:
<?php class Myclass { public $attriable; public $one = "this is one"; public $two = "this is two"; function construct() { } function one($one) { $this->one=$one; $this->attriable = $this->one; } function one($one, $two) { $this->one=$one; $this->two=$two; $this->attriable = $this->one . $this->two; } function display() { echo $this->attriable; } } $one = "this is my class"; $two = "Im the best"; $myclass = new myclass(); $myclass->one($one); $myclass->display(); $myclass->one($one, $two); $myclass->display(); //本例的做法,在 PHP 中是不正确的! ?>
メソッドのオーバーロード
を実装するための独自のメソッド セットを備えています (それが良いか悪いかはここでは議論しません)。 PHP5 のクラスは PHP4 のクラスよりもはるかに強力ですが、「オーバーロード」の問題は期待したほど「改善」されていません。 「オーバーロード」は、C++、Java、C# などの「強く」型付けされた言語のさまざまなパラメーター型を通じて実現できます。 Javaのように「固定パラメータ」を渡す言語では、パラメータの数だけ渡すこともできますが、PHPは弱い型付け言語なので、上記のような「オーバーロード」は起こりません。 PHP5 では、get、set、call といういくつかの特別なメソッドを通じてオーバーロードを実行できます。 Zend エンジンがメンバーにアクセスしようとして見つからなかった場合、PHP はこれらのメソッドを呼び出します。
次の例では、属性変数配列へのすべてのアクセスを get と set で置き換えます。必要に応じて、任意のタイプのフィルタリングを実装することもできます。たとえば、スクリプトでプロパティ値の設定を無効にしたり、特定のプレフィックスで開始したり、特定の種類の値を含めたりすることができます。 call メソッドは、未定義のメソッドを呼び出す方法を示しています。未定義のメソッドを呼び出すと、メソッド名とメソッドが受け取ったパラメータが呼び出しメソッドに渡され、PHP は呼び出し値を未定義のメソッドに返します。
コードは次のとおりです:
<?php class Overloader { private $properties = array(); function get($property_name) { if(isset($this->properties[$property_name])) { return($this->properties[$property_name]); } else { return(NULL); } } function set($property_name, $value) { $this->properties[$property_name] = $value; } public function call($method, $p) { print("Invoking $method()<br>\n"); //print("Arguments: "); //print_r($args); if($method == 'display') { if(is_object($p[0])) $this->displayObject($p[0]); else if(is_array($p[0])) $this->displayArray($p[0]); else $this->displayScalar($p[0]); } } public function displayObject($p) { echo ("你传入的是个对象,内容如下:<br>"); print_r($p); echo "<hr>"; } public function displayArray($p) { echo ("你传入的是个数组,内容如下:<br>"); print_r($p); echo "<hr>"; } public function displayScalar($p) { echo ("你传入的是个单独变量,内容如下:<br>" . $p); echo "<hr>"; } } $o = new Overloader(); //调用 set() 给一个不存在的属性变量赋值 $o->dynaProp = "Dynamic Content"; //调用 get() print($o->dynaProp . "<br>\n"); //调用 call() //$o->dynaMethod("Leon", "Zeev"); $o->display(array(1,2,3)); $o->display('Cat'); ?>
以上がPHP メソッドをオーバーロードする 2 つの方法を比較する例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。