This article mainly introduces the new magic method _ invoke in PHP5.3. For more information, see the new magic method named _ invoke in PHP since version 5.3, by using this method, you can directly call an object after creating an instance. Example:
class testClass{public function __invoke{print "hello world";}}$n = new testClass;$n();
The execution result is:
hello world。
Official php example:
class CallableClass{public function __invoke($x){var_dump($x);}}$obj = new CallableClass;$obj(5);var_dump(is_callable($obj));
Appendix:Other PHP magic methods:
Php classes can use magic methods. It specifies that all methods starting with two underscores (_) are retained as magic methods. Therefore, we recommend that you do not start with _ in the function name unless you want to reload the existing magic methods.
The function names _ construct, _ destruct, _ call, _ callStatic, _ get, _ set, _ isset, _ unset, _ sleep, _ wakeup, _ toString, _ invoke, _ set_state and _ clone are magical in PHP classes. you cannot have functions with these names in any of your classes unless you want the magic functionality associated with them.
The following two methods are designed for attributes that are not declared in the class and their parent class.
_ Get ($ property) when an undefined property is called, this method is triggered and the passed parameter is the name of the Accessed property.
_ Set ($ property, $ value) is triggered when an undefined attribute is assigned a value. The passed parameter is the set attribute name and value.
Here, there is no declaration that the access control is "proteced" and "private" when an object is called (that is, an attribute with no access permission ).
Similar to the _ get method and _ set method, there is no declaration here, including the access control for the proteced and private attributes when the object is called (that is, the attribute with no access permission ).
The undefined method here includes methods without access permission. if the method does not exist, find this method in the parent class. if the parent class does not exist, call the _ call () method of this class () if the _ call () method does not exist in this class, find the _ call () method in the parent class.
_ Autoload functionIt is automatically called when trying to use a class that has not been defined. By calling this function, the script engine has the last chance to load the required class before a php error fails.
Note:The exception thrown in the _ autoload function cannot be caught by the catch statement block and cause fatal errors. Therefore, the function itself should be captured.
_ Construct constructorThis method is called when an object is created. the advantage of using this method relative to php4 is that the constructor has a unique name regardless of the name of the class in which it is located. in this way, you do not need to change the name of the constructor when changing the class name.
_ Destruct destructorPhp will call this method before the object is destroyed (that is, before it is cleared from the memory. By default, php only releases the memory occupied by object properties and destroys object-related resources. The Destructor allows you to execute arbitrary code after using an object to clear the memory. When php decides that your script is no longer related to objects, the destructor will be called.
In the namespace of a function, this occurs when the function returns. For global variables, this occurs at the end of the script. If you want to explicitly destroy an object, you can assign any other value to the variable pointing to the object. Usually, the variable is assigned null or unset is called.
Object assignment in php5 is a reference assignment. if you want to copy an object, you need to use the clone method. when you call this method, the object will automatically call the _ clone magic method, if you need to perform some initialization operations on object replication, you can implement them in the _ clone method.
_ Tostring methodIt is automatically called when an object is converted into a string, for example, when an object is printed using echo.
Before php5.2.0, the __tostring method takes effect only when echo () or print () is used in combination. After php5.2.0, it can take effect in any string environment (for example, using the % s modifier through printf (), but not for non-string environment (such as using the % d modifier ). From php5.2.0, if an undefined _ tostring method object is converted to a string, an e_recoverable_error error is returned.
_ WakeupCalled during deserialization
Serialize () checks whether the class has a function named _ sleep. In this case, the function will run before any serialization. It can clear the object and should return an array containing all variable names to be serialized in the object.
The purpose of _ sleep is to close any database connection that an object may have, submit data in waiting or perform similar cleanup tasks. In addition, this function is useful if a very large object does not need to be fully stored.
PHP, on the contrary, unserialize () checks the existence of a function with the magic name _ wakeup. If yes, this function can reconstruct any resources that an object may have. _ Wakeup is used to reconstruct any database connections that may be lost during serialization and process other re-initialization tasks.
When you try to call an object by calling a function, the __invoke method is automatically called.
It works in a way similar to the _ call () magic method, __callstatic () is used to handle static method calls.
Php does enhance the definition of the _ callstatic () method. it must be public and declared as static. Similarly, the __call () magic method must be defined as public, and all other magic methods must be.