search
HomeBackend DevelopmentPHP TutorialCommon magic method functions and usage examples in PHP, php magic_PHP tutorial

Common magic method functions and usage examples in PHP, php magic

Overview

In object-oriented programming, PHP provides a series of magic methods, which provide a lot of convenience for programming. Magic methods in PHP usually start with __ (two underscores) and do not require explicit calls but are triggered by certain conditions. This article briefly summarizes the magic methods available in PHP.

Before you begin

Before summarizing PHP’s magic methods, let’s define two classes for use in later examples:
Copy code The code is as follows:
class Device {
Public $name;
Public $battery;
Public $data = array();
Public $connection;

protected function connect() {
           $this->connection = 'resource';
echo $this->name . ' connected' . PHP_EOL;
}

protected function disconnect() {
           $this->connection = null;
echo $this->name . ' disconnected' . PHP_EOL;
}
}

class Battery {
private $charge = 0;

Public function setCharge($charge) {
          $charge = (int)$charge;
              if($charge                $charge = 0;
}
         elseif($charge > 100) {
$charge = 100;
}
$this->charge = $charge;
}
}
?>

The Device class has four member properties and two member methods. The Battery class has one member property and one member method.

Constructor and destructor

The constructor and destructor are called when the object is created and destroyed respectively. When an object is "destroyed", it means that there is no reference to the object. For example, if the variable that refers to the object is deleted (unset), reassigned, or the script execution ends, the destructor will be called.

__construct()

__construct() The constructor is by far the most commonly used function. When creating an object, you can do some initialization work in the constructor. You can define any number of parameters for the constructor, as long as the corresponding number of parameters is passed in when instantiating. Any exception that occurs in the constructor prevents the object from being created.

Copy code The code is as follows:
class Device {
Public function __construct(Battery $battery, $name) {
$this->battery = $battery;
          $this->name = $name;
$this->connect();
}
}

In the above sample code, the constructor of the Device class assigns values ​​to member properties and calls the connect() method.
Copy code The code is as follows:
Declaring the constructor as a private method prevents the object from being created outside the class, which is often used in the simplex pattern.

__desctruct()

The destructor is usually called when the object is destroyed, and the destructor does not receive any parameters. Some cleanup work is often performed in the destructor, such as closing the database connection, etc.

Property Overloading

One thing to note is that "overloading" in PHP is not the same as overloading in most other languages, although they all implement the same function.
The two magic methods involved in property overloading are mainly used to handle property access, defining what happens when we try to access a non-existent (or inaccessible) property.

__get()

The magic method __get() will be called when we try to access a property that does not exist. It receives a parameter that represents the name of the accessed attribute and returns the value of the attribute. In the Device class above, there is a data attribute, which plays a role here, as shown in the following code:
Copy code The code is as follows:
class Device {
Public function __get($name) {
If(array_key_exists($name, $this->data)) {
                return $this->data[$name];
}
        return null;
}
}

The most common use of this magic method is to extend access control by creating a "read-only" attribute. In the above Battery class, there is a private attribute $charge. We can extend this attribute through the __get() magic method to be readable but not modifyable outside the class. The code is as follows:
Copy code The code is as follows:
class Battery {
private $charge = 0;

Public function __get($name) {
If(isset($this->$name)) {
               return $this->$name;
}
        return null;
}
}

__set()

The

__set() magic method will be called when we try to modify an inaccessible property. It receives two parameters, one representing the name of the property and one representing the value of the property. The sample code is as follows:
Copy code The code is as follows:
class Device {
Public function __set($name, $value) {
                // use the property name as the array key
           $this->data[$name] = $value;
}
}

__isset()

The __isset() magic method is called when the isset() method is called on an inaccessible property. It receives a parameter representing the name of the property. It should return a Boolean value indicating whether the property exists. The code is as follows:
Copy code The code is as follows:
class Device {
Public function __isset($name) {
           return array_key_exists($name, $this->data);
}
}

__unset()

The __unset() magic method will be called when the unset() function is called to destroy an inaccessible attribute. It receives a parameter expressing the name of the attribute.

Convert object to string

Sometimes we need to express objects in the form of strings. If we print an object directly, the program will output an error message: PHP Catchable fatal error: Object of class Device could not be converted to string

__toString()

__toString() will be called when we use the object as a string. It does not receive any parameters. This method allows us to define the representation of the object. The code is as follows:
Copy code The code is as follows:
class Device {
Public function __toString() {
​ ​ ​ $connected = (isset($this->connection)) ? 'connected' : 'disconnected';
$count = count($this->data);
Return $this->name . ' is ' . $connected . ' with ' . $count . ' items in memory' . PHP_EOL;
}
...
}

__set_state()(PHP 5.1)

Static magic method __set_state(), this method will be called when we use the var_export() function to output the object. The var_export() function is used to convert PHP variables into PHP code. It receives an associative array containing object attribute values ​​as a parameter. The sample code is as follows:
Copy code The code is as follows:
class Battery {
//...
Public static function __set_state(array $array) {
          $obj = new self();
           $obj->setCharge($array['charge']);
         return $obj;
}
//...
}

Clone object

By default, objects are passed by reference. Therefore, when you assign an object to another variable, you only create a reference to the object and do not copy the object. In order to actually copy an object, we need to use the clone keyword.
This "pass by reference" strategy also applies to objects contained within objects. Even if we clone an object, any objects inside the object will not be cloned, so the end result is that both objects share the same internal object. The sample code is as follows:
Copy code The code is as follows:
$device = new Device(new Battery(), 'iMagic');
$device2 = clone $device;

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

__clone()

__clone() magic method __clone() can solve the above problem. This magic method is called when the clone keyword is used on an object. In this magic method, we can clone any sub-object. The code is as follows:
Copy code The code is as follows:
class Device {
...
Public function __clone() {
              // copy our Battery object
$this->battery = clone $this->battery;
}
...
}

Object serialization

Serialization is the process of converting arbitrary data into string format. Serialization is typically used to store the entire object in a database or write it to a file. When deserializing the stored data, we can get the object before serialization. However, not all data can be serialized, such as database connections. Luckily, there's a magic trick to help us solve this problem.

__sleep()

The magic method __sleep() will be called when serializing an object (calling serialize()). It takes no parameters and should return an array containing all properties that should be serialized. Within this magic method, you can also perform some other operations.
One thing to note is that do not perform any destruction operations in this function, as this may affect the running object.

The sample code is as follows:
Copy code The code is as follows:
class Device {
Public $name;
Public $battery;
Public $data = array();
Public $connection;
//...
Public function __sleep() {
          return array('name', 'battery', 'data');
}
//...
}

__wakeup()

The magic method __wakeup() will be called when deserializing the stored object. It does not receive any parameters and does not return any value. You can use it to handle database connections or resources that are lost during serialization. The code is as follows:
Copy code The code is as follows:
class Device {
//...
Public function __wakeup() {
                // reconnect to the network
           $this->connect();
}
//...
}

Method overloading

PHP also has two magic methods __call() and __callStatic() related to member methods. These two magic methods are similar to attribute overloading methods.

__call()

The magic method __call() will be called when calling a method that does not exist or is inaccessible. It receives two parameters, one is the name of the method to be called, and the other is an array containing the function parameters. We can use this method to call the function of the same name in the child object.

In this example, pay attention to the function call_user_func_array(), which allows us to dynamically call a named function.

The sample code is as follows:
Copy code The code is as follows:
class Device {
//...
Public function __call($name, $arguments) {
// make sure our child object has this method
If(method_exists($this->connection, $name)) {
                       // forward the call to our child object
                  return call_user_func_array(array($this->connection, $name), $arguments);
}
        return null;
}
//...
}

__callStatic()

The magic method __callStatic() has the same function as __call(). The only difference is that this method will be called when trying to access a non-existent or inaccessible static method. The sample code is as follows:
Copy code The code is as follows:
class Device {
//...
Public static function __callStatic($name, $arguments) {
              // make sure our class has this method
If(method_exists('Connection', $name)) {
                        // forward the static call to our class
                 return call_user_func_array(array('Connection', $name), $arguments);
}
        return null;
}
//...
}

Object as function

Sometimes we need to use objects as functions. Using objects as functions is just like using other ordinary functions, and you can pass parameters.

__invoke()(PHP 5.3)

The magic method __invoke() is called when trying to use the object as a function. Any parameters defined in this method will be used as parameters of the function. The sample code is as follows:
Copy code The code is as follows:
class Device {
//...
Public function __invoke($data) {
echo $data;
}
//...
}
$device = new Device(new Battery(), 'iMagic');
$device('test');
// equiv to $device->__invoke('test')
// Outputs: test

Others:__autoload()

The __autoload() method is not a magic method, but it is very useful. However, with the update of the PHP version, this function is no longer recommended and is replaced by the spl_auto_register() function.

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/1024903.htmlTechArticle Common magic method functions and usage examples in PHP, php magic overview In object-oriented programming, PHP provides A series of magic methods that provide a lot for programming...
Statement
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
php怎么把负数转为正整数php怎么把负数转为正整数Apr 19, 2022 pm 08:59 PM

php把负数转为正整数的方法:1、使用abs()函数将负数转为正数,使用intval()函数对正数取整,转为正整数,语法“intval(abs($number))”;2、利用“~”位运算符将负数取反加一,语法“~$number + 1”。

php怎么实现几秒后执行一个函数php怎么实现几秒后执行一个函数Apr 24, 2022 pm 01:12 PM

实现方法:1、使用“sleep(延迟秒数)”语句,可延迟执行函数若干秒;2、使用“time_nanosleep(延迟秒数,延迟纳秒数)”语句,可延迟执行函数若干秒和纳秒;3、使用“time_sleep_until(time()+7)”语句。

php怎么除以100保留两位小数php怎么除以100保留两位小数Apr 22, 2022 pm 06:23 PM

php除以100保留两位小数的方法:1、利用“/”运算符进行除法运算,语法“数值 / 100”;2、使用“number_format(除法结果, 2)”或“sprintf("%.2f",除法结果)”语句进行四舍五入的处理值,并保留两位小数。

php字符串有没有下标php字符串有没有下标Apr 24, 2022 am 11:49 AM

php字符串有下标。在PHP中,下标不仅可以应用于数组和对象,还可应用于字符串,利用字符串的下标和中括号“[]”可以访问指定索引位置的字符,并对该字符进行读写,语法“字符串名[下标值]”;字符串的下标值(索引值)只能是整数类型,起始值为0。

php怎么根据年月日判断是一年的第几天php怎么根据年月日判断是一年的第几天Apr 22, 2022 pm 05:02 PM

判断方法:1、使用“strtotime("年-月-日")”语句将给定的年月日转换为时间戳格式;2、用“date("z",时间戳)+1”语句计算指定时间戳是一年的第几天。date()返回的天数是从0开始计算的,因此真实天数需要在此基础上加1。

php怎么读取字符串后几个字符php怎么读取字符串后几个字符Apr 22, 2022 pm 08:31 PM

在php中,可以使用substr()函数来读取字符串后几个字符,只需要将该函数的第二个参数设置为负值,第三个参数省略即可;语法为“substr(字符串,-n)”,表示读取从字符串结尾处向前数第n个字符开始,直到字符串结尾的全部字符。

php怎么替换nbsp空格符php怎么替换nbsp空格符Apr 24, 2022 pm 02:55 PM

方法:1、用“str_replace(" ","其他字符",$str)”语句,可将nbsp符替换为其他字符;2、用“preg_replace("/(\s|\&nbsp\;||\xc2\xa0)/","其他字符",$str)”语句。

php怎么判断有没有小数点php怎么判断有没有小数点Apr 20, 2022 pm 08:12 PM

php判断有没有小数点的方法:1、使用“strpos(数字字符串,'.')”语法,如果返回小数点在字符串中第一次出现的位置,则有小数点;2、使用“strrpos(数字字符串,'.')”语句,如果返回小数点在字符串中最后一次出现的位置,则有。

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Tools

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),

WebStorm Mac version

WebStorm Mac version

Useful JavaScript development tools

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Powerful PHP integrated development environment