


PHP reference counting memory management mechanism and garbage collection mechanism
This article shares with you the reference counting memory management mechanism and garbage collection mechanism of PHP. Friends who need help can refer to it
Reference assignment
1 2 |
|
Above In the code, I assign a string to variable a, and then assign the reference of a to variable b. Obviously, the memory pointing at this time should be like this:
1 |
|
a and b point to the same memory area (variable container zval), we pass var_dump($a, $b)
gets string(5) "apple" string(5) "apple"
, which is what we expected.
unset function and reference counting
unset function
Suppose I want to release the string 'apple'
from memory. This is what I did:
1 |
|
But by printing the information of the two variables $a
$b
again, I got this result: Notice: Undefined variable : a
and string(5) "apple"
. Strange, $a
$b
points to the same variable container, and $a
is clearly released, why $b is still 'apple'
.
Actually, unset()
only destroys a variable symbol a
(pointer) and does not release the variable container, so after the operation is completed , the memory pointer just becomes like this:
1 |
|
Reference count
The reference count (reference count) is a piece of information stored in each variable container. It indicates how much the current variable container is being used. referenced by variable symbols.
As in the previous example, unset() does not release the variable container pointed by the variable, but only destroys the variable symbol. At the same time, reduce the reference count in the variable container by 1. When the reference count is 0, that is to say, when the variable container is not referenced by any variable, will trigger PHP's garbage collection (error ), it will be released (correct).
Correction of the above minor error: This simple reference counting method is the memory management mechanism before PHP 5.2. It cannot be called a garbage collection mechanism. The garbage collection mechanism was only introduced in PHP 5.3. The garbage collection mechanism is to solve the shortcomings of this simple reference counting memory management mechanism (that is, memory leaks caused by circular references, which will be explained below)
Back to the topic, we use code to verify Let’s look at the previous conclusion:
1 2 3 4 5 6 7 8 |
|
1 2 3 4 5 6 7 8 |
|
Directly release
So what can we do to really release the memory occupied by 'apple'
?
Using the above method, we can unset($a)
and then unset($b)
to destroy all references to the variable container and decrement the reference count. If it is 0, it will naturally be released.
Of course, there is a more direct method:
1 |
|
Direct assignment null
will empty the memory area pointed to by $a
and The reference count returns to zero and the memory is released.
Memory after script execution ends
For general web programs (in fpm mode), PHP execution is single-thread synchronous blocking type. After the script execution ends, the script All memory used will be released. So, does it make sense for us to manually release the memory?
In fact, this question has been answered for a long time. I recommend everyone to read an article published by @laruence in 2012:
Please release resources manually
Defects of the reference counting memory management mechanism: circular references
Now let’s talk about the flaws of the reference counting memory management mechanism mentioned before.
When the reference count of a variable container is 0, PHP will perform garbage collection. However, have you ever thought about it, there is a situation that will cause the reference count of a variable container to never be reduced to 0. For example:
1 2 |
|
We see that the $a
array The two elements are themselves. Then, the reference count of the variable container storing the array is 2, one reference is the variable a
, and the other reference is the second element of the array - index 1
.
So, if we unset($a)
at this time, the reference count of the variable container storing the array will be reduced by 1 , but there is still one reference, which is the element 1
of the array. Now the reference structure becomes like this:
Circular Reference.
Fortunately, in fpm mode, when the execution of the requested script ends, PHP will release all memory used in the script, including this structure. However, what if it is a php program under the daemon process? Such as swoole. Urgent problems that need to be solved in this php (already solved, see below).
Synchronization algorithm introduced in PHP 5.3.0
Traditionally, the reference counting memory mechanism used by PHP in the past cannot handle memory leaks of circular references. However, the synchronization algorithm in the 5.3.0 PHP usage article » Concurrent Cycle Collection in Reference Counted Systems solves this memory leak problem. This algorithm is PHP's garbage collection mechanism.
The implementation and process of the specific algorithm are a bit complicated. Please read the official documentation. I will not go into details here. I also attach several links to articles explaining the algorithm process, which are relatively straightforward:
http://php.net/manual/zh/feat... Official documentation
http://www.cnblogs.com/leoo2s...
https://blog.csdn.net/phpkern. ..
Finally, let me quote these two paragraphs from Niao Ge’s article to illustrate the problem:
Before PHP5.2, PHP used reference count for resource management. When a When the reference count of zval reaches 0, it will be released. Although there is a cycle reference, this design is not a problem for developing Web scripts, because the characteristics of Web scripts and its goal are to execute The time is short and will not run for a long time. Resource leaks caused by circular references will be released at the end of the request. In other words, releasing resources at the end of the request is a remedial measure (backup).However, as PHP is used by more and more people, and many people use PHP in some background scripts. These scripts are characterized by long-term running. If there are circular references, causing the reference count to be unable to release unused resources in time, the script will eventually run out of memory. Exit when exhausted.
So after PHP5.3, we introduced GC. In other words, we introduced GC to solve problems that users cannot solve.
The above is the detailed content of PHP reference counting memory management mechanism and garbage collection mechanism. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



PHP 8.4 brings several new features, security improvements, and performance improvements with healthy amounts of feature deprecations and removals. This guide explains how to install PHP 8.4 or upgrade to PHP 8.4 on Ubuntu, Debian, or their derivati

If you are an experienced PHP developer, you might have the feeling that you’ve been there and done that already.You have developed a significant number of applications, debugged millions of lines of code, and tweaked a bunch of scripts to achieve op

Visual Studio Code, also known as VS Code, is a free source code editor — or integrated development environment (IDE) — available for all major operating systems. With a large collection of extensions for many programming languages, VS Code can be c

JWT is an open standard based on JSON, used to securely transmit information between parties, mainly for identity authentication and information exchange. 1. JWT consists of three parts: Header, Payload and Signature. 2. The working principle of JWT includes three steps: generating JWT, verifying JWT and parsing Payload. 3. When using JWT for authentication in PHP, JWT can be generated and verified, and user role and permission information can be included in advanced usage. 4. Common errors include signature verification failure, token expiration, and payload oversized. Debugging skills include using debugging tools and logging. 5. Performance optimization and best practices include using appropriate signature algorithms, setting validity periods reasonably,

This tutorial demonstrates how to efficiently process XML documents using PHP. XML (eXtensible Markup Language) is a versatile text-based markup language designed for both human readability and machine parsing. It's commonly used for data storage an

A string is a sequence of characters, including letters, numbers, and symbols. This tutorial will learn how to calculate the number of vowels in a given string in PHP using different methods. The vowels in English are a, e, i, o, u, and they can be uppercase or lowercase. What is a vowel? Vowels are alphabetic characters that represent a specific pronunciation. There are five vowels in English, including uppercase and lowercase: a, e, i, o, u Example 1 Input: String = "Tutorialspoint" Output: 6 explain The vowels in the string "Tutorialspoint" are u, o, i, a, o, i. There are 6 yuan in total

Static binding (static::) implements late static binding (LSB) in PHP, allowing calling classes to be referenced in static contexts rather than defining classes. 1) The parsing process is performed at runtime, 2) Look up the call class in the inheritance relationship, 3) It may bring performance overhead.

What are the magic methods of PHP? PHP's magic methods include: 1.\_\_construct, used to initialize objects; 2.\_\_destruct, used to clean up resources; 3.\_\_call, handle non-existent method calls; 4.\_\_get, implement dynamic attribute access; 5.\_\_set, implement dynamic attribute settings. These methods are automatically called in certain situations, improving code flexibility and efficiency.
