A direct look at PHP reflection learning to instantiate class operations without using the new method

coldplay.xixi
Release: 2023-04-09 10:46:01
forward
2580 people have browsed it

A direct look at PHP reflection learning to instantiate class operations without using the new method

The example in this article describes the use of PHP reflection learning to instantiate class operations without the new method. I share it with you for your reference. The details are as follows:

The previous article on PHP Reflection Getting Started Example briefly introduced how to use several common classes of PHP reflection, but you may still not be able to imagine what you can do with reflection. Come on,

Next I will use the reflection class to do something. Everyone knows that you need to use the new keyword to instantiate a class. Is it okay without usingnew? The answer is yes, it can be achieved using reflection:

Related learning recommendations:PHP programming from entry to proficiency

First create a file student .php:

id = $id; $this->name = $name; } public function study() { echo $this->name.' is learning.....'.PHP_EOL; } public function showBag(){ echo "My bag have ".$this->bag->all(); } }
Copy after login

Create a new file run.php

isInstantiable()) { throw new Exception("类{$class} 不存在"); } $constructor = $ref->getConstructor(); if(is_null($constructor)) { return new $class; } $params = $constructor->getParameters(); $resolveParams = []; foreach ($params as $key=>$value) { $name = $value->getName(); if(isset($vars[$name])) { $resolveParams[] = $vars[$name]; } else { $default = $value->isDefaultValueAvailable() ? $value->getDefaultValue() : null; if(is_null($default)) { if($value->getClass()) { $resolveParams[] = make($value->getClass()->getName(), $vars); } else { throw new Exception("{$name} 没有传值且没有默认值。"); } } else { $resolveParams[] = $default; } } } return $ref->newInstanceArgs($resolveParams); }
Copy after login

run.php. The make function is the function we write to instantiate the class. The first parameter is passed in the class name. , the second parameter is the parameter data that needs to be passed in to the constructor of the class.

There are several situations depending on the parameters of Student's constructor: (The following code, please append it to run.php according to different situations)

Case 1: No $ is provided The value of name

try { $stu = make('Student', ['id' => 1]); print_r($stu); $stu->study(); } catch (Exception $e) { echo $e->getMessage(); }
Copy after login

When $name does not have a default value in the constructor, an error will be reported. You can slightly modify the Student class to provide a default value for $name, and then it will not An error was reported.

Case 2 provides the value of $name

try { $stu = make('Student', ['id' => 1, 'name' => 'li']); print_r($stu); $stu->study(); } catch (Exception $e) { echo $e->getMessage(); }
Copy after login

Case 3, let’s change student.php

id = $id; $this->name = $name; $this->bag = $bag; } public function study() { echo $this->name.' is learning.....'.PHP_EOL; } public function showBag(){ echo "My bag is ".$this->bag->name(); } }
Copy after login

As you can see, a parameter $bag is added to the Student class, the type is Bag

Run it now

 1, 'name' => 'li']); print_r($stu); $stu->study(); $stu->showBag(); } catch (Exception $e) { echo $e->getMessage(); }
Copy after login

You can see that the third parameter $bag of the constructor is automatically instantiated ified, and then passed to the constructor of the Student class. This part is very critical. This place can be used to implement dependency injection. We do not have to manually instantiate the object. We can automatically instantiate the object according to the corresponding class of the parameter. This achieves decoupling between classes. If you have learned Laravel, you should be familiar with this.

The above is the detailed content of A direct look at PHP reflection learning to instantiate class operations without using the new method. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:jb51.net
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!