Home > Backend Development > PHP Tutorial > Magic methods in php classes and automatic loading of classes

Magic methods in php classes and automatic loading of classes

WBOY
Release: 2016-07-25 09:03:52
Original
949 people have browsed it
  1. class Connection {
  2. protected $link;
  3. private $server, $username, $password, $db;
  4. public function __construct($server, $username, $password, $db) {
  5. $this- >server = $server;
  6. $this->username = $username;
  7. $this->password = $password;
  8. $this->db = $db;
  9. $this->connect();
  10. }
  11. private function connect() {
  12. $this->link = mysql_connect($this->server, $this->username, $this->password);
  13. mysql_select_db($this-> db, $this->link);
  14. }
  15. public function __sleep() {//You only need to save the values ​​of these attributes when serializing
  16. return array('server', 'username', 'password', 'db ');//Must return an array
  17. }
  18. public function __wakeup() { //Connect to the database immediately after deserializing the object
  19. $this->connect();
  20. }
  21. }
Copy code

__toString(): Called when trying to use the object as a string, it returns a string, similar to toString() of js objects

__invoke(): Called when an object is called as a function. like $object($a,$b) will call $object->__invoke($a,$b)

__set_state(): When var_export() is called on an object, its return value will be printed

__clone(): It is called when using the clone operation on an object and has no return value. This method can be used to modify the properties of the object obtained by clone before returning it so that the object obtained by clone can have different property values ​​​​from the object being operated on, but it cannot be returned by returning null or false to prevent the object cloning operation. The object obtained by the clone operation is not returned through the return value of this method.

Notes: The __get and __set methods can be often used to flexibly handle access to object private attributes and protected attributes. Because when a PHP object uses isset() or empty() to determine a method, it will not consider the method to be an accessible attribute (be careful if you write too much javascript. In PHP, attributes are attributes, methods are methods, and cannot be confused) When using __get, you may use isset($this->key) to judge attributes in this method, especially when you need to deal with private attributes. At this time, you should pay attention to whether __set() is defined and how to define it. To avoid misjudgment. If an object's method does not require passing parameters when calling, or the passing parameters are fixed, you can attribute the method through the __get() method, and automatically call the method in __get() and return the value.

For example, define the __get method in the class as follows:

  1. public function __get($key){

  2. if(property_exists($this,$key)){
  3. return $this->$key; //Private and protected properties allow access
  4. }else if(method_exists($this,'get'.$key)){
  5. return $this->{'get'.$key}();
  6. //or....
  7. // $methodName = 'get'.$key;
  8. //return $this-> $methodName();
  9. }else{
  10. thrown new Exception('class '.__class__.' do not has property '.$key);
  11. }
  12. }

  13. //Method attributed access:

  14. $obj->getModelName();
  15. $obj->ModelName; //Attributed

Copy code

unserialize() method: When trying to deserialize an object, this function needs to know the class of the object. If the serialization string is obtained from other ways and the class of the object is not defined in the script environment, it is required Import the file of the class. The second parameter of unserialize() is an optional callback parameter, which is used to import the file where the class is located. function importClass($calssName){ include('xxxx.php'); //File containing this class } unserialize($objstr,$callbackName);

Automatic loading of classes: __autoload()

__autoload() is a function agreed in the PHP execution environment rather than a method of a certain class. If a class is not loaded into the current file before use, the __autoload() function will be automatically called to load the class. Usually these classes The loading rules are all agreed. For example, these classes are included in files named after the class names. This method can realize on-demand loading of classes and avoid loading unnecessary classes before script execution, thereby reducing resource usage and submission performance.

Note: Errors within __autoload() cannot be caught by try-catch.

  1. function __autoload($class_name){
  2. require_once(PATH.'/calsses/'.$class_name.'.php');
  3. }
  4. $obj1 = new mycalss1();
Copy code

Register the function automatically called by __autoload(): The spl code base is automatically enabled by default after PHP5.0 spl_autoload_register([callback]); //Instead of writing the specific loading code in __autoload(), you can use this function to register the callback function.

If you use a class method as a callback function, you need to pass in an array: spl_autoload_register(array('class_name'|$obj,'method_name'));

For example: spl_autoload_register(array($this,'autoloadClass')); spl_autoload_register(array('YiiBase','autoload'));//Implementation of the autoloading class of the YII framework, the YiiBase class implements an autoload method. spl_autoload_register() can register multiple load functions, and all registered load functions will be tried one by one before successfully loading the class file. This is useful when different classes use different logic to import class files. spl_autoload_unregister(); //Cancel a registered load function, the parameters are the same as spl_autoload_register(). spl_autoload_functions(); // Returns all registered __autoload() functions in array

spl_autoload(class_name[,file_extensions]); //Default implementation of __autoload() function. If no function name is passed in when spl_autoload_register() is called, this function will be used by default. The execution rules of this function are: The class name is converted to lowercase as the file name, and the passed-in file_extensions (multiple extensions are separated by commas, default (.inc and .php) as the extension, try to search in the include paths set in php.ini based on the file name obtained.

spl_autoload_call(class_name);//Manually call all registered __autoload() functions to actively load class files spl_autoload_extensions([file_extentions]); //Register or return the file extensions that can be used in spl_autoload(). The extension can be in the form of .a.b, for example: spl_autoload_extentions(".class.php"); spl_autoload_register(); //Use spl_autoload() to try to automatically load class files //In this way spl_autoload('myclassName'); will try to load the file "myclassName.class.php" .



source:php.cn
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
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template