


An in-depth analysis of PHP memory management: Who touched my memory_PHP tutorial
First let us look at a problem: The output of the following code,
var_dump(memory_get_usage ());
$a = "laruence";
var_dump(memory_get_usage());
unset($a);
var_dump(memory_get_usage());
output(in my On your personal computer, it may vary due to different systems, PHP versions, and loaded extensions):
int(90440)
int(90640)
int(90472)
Notice that 90472-90440=32, so there are various conclusions. Some people say that PHP’s unset does not really release memory, and some say that PHP’s unset only releases large variables (a large number of strings, large Array), some people even say that it is meaningless to discuss memory at the PHP level.
So, will unset release memory?
These 32 words Where did the section go?
To answer this question, I will start from two aspects:
Where did these 32 bytes go?
First we have to break a thinking: PHP Unlike the C language, memory allocation will occur only when you explicitly call the memory allocation related API.
That is to say, in PHP, there are many memory allocation processes that we cannot see.
For example:
$a = "laruence";
The implicit memory allocation points are:
1.1. Allocate memory for the variable name and store it in Symbol table
2.2. Allocate memory for variable values
So, you can’t just look at the appearance.
Second, don’t doubt that PHP’s unset will indeed release memory, but this release is not in the sense of C programming The release is not handed back to the OS.
For PHP, it provides a set of memory management API similar to the C language for memory allocation:
emalloc(size_t size);
efree(void *ptr);
ecalloc(size_t nmemb, size_t size);
erealloc( void *ptr, size_t size);
estrdup(const char *s);
estrndup(const char *s, unsigned int length);
The API meaning of these APIs and C Correspondingly, memory is managed internally in PHP through these APIs.
When we call emalloc to apply for memory, PHP does not simply ask the OS for memory, but asks the OS for a large piece of memory, and then Allocate one of the blocks to the applicant, so that when there is logic to apply for memory, there is no need to apply for memory from the OS, avoiding frequent system calls.
For example, the following example:
var_dump(memory_get_usage(TRUE)); // Note that what is obtained is real_size
$a = "laruence";
var_dump(memory_get_usage(TRUE));
unset($a);
var_dump(memory_get_usage(TRUE));
output :
int(262144)
int(262144)
int(262144)
That is, when we define the variable $a, PHP does not apply for new memory from the system .
Similarly, when we call efree to release memory, PHP will not return the memory to the OS, but will add this memory to the free memory list it maintains. For small pieces of memory, More likely, put it in the memory cache list (postscript, some versions of PHP, such as PHP5.2.4, 5.2.6, 5.2.8 that I have verified, will not when calling get_memory_usage() Subtracting the available memory block size in the memory cache list, it seems that the memory remains unchanged after unset).
Now let me answer where these 32 bytes went, just like what I just said , many memory allocation processes are not explicit. You will understand after reading the following code:
var_dump("I am Laruence, From http://www.laruence.com");
var_dump(memory_get_usage());
$a = "laruence";
var_dump(memory_get_usage());
unset($a);
var_dump(memory_get_usage());
Output:
string(43) "I am Laruence, From http:// /www.laruence.com"
int(90808) //Before assignment
int(90976)
int(90808) //Yes, the memory is released normally
90808-90808 = 0, It's normal, that is to say, these 32 bytes are occupied by the output function (strictly speaking, they are occupied by the output Header)
An array that only increases but does not decrease
Hashtable is the core structure of PHP. Arrays are also represented by it, and the symbol table is also an associative array. For the following code:
var_dump("I am Laruence, From http://www.laruence.com");
var_dump(memory_get_usage());
$array = array_fill(1, 100, "laruence ");
foreach ($array as $key => $value) {
${$value . $key} = NULL;
}
var_dump(memory_get_usage());
foreach ($array as $key=> $value) {
unset(${$value . $key});
}
var_dump(memory_get_usage());
We defined 100 variables, and then clicked Unset to see the output:
string(43) "I am Laruence, From http://www.laruence.com"
int(93560)
int(118848)
int(104448)
Wow, why is there so much less memory?
This is because for Hashtable, when defining it, it is impossible to allocate enough memory blocks at one time to save unknown number of elements, so PHP will only allocate a small part of the memory block to the HashTable during initialization. When it is not enough, it will RESIZE to expand the capacity,
and the Hashtable can only be expanded, not reduced. For In the above example, when we stored 100 variables, the symbol table was not enough and we made an expansion. When we unset the 100 variables in turn, the memory occupied by the variables was released (118848 – 104448). But the symbol table has not shrunk, so the small amount of memory is taken up by the symbol table itself...
Now, do you have a preliminary understanding of PHP's memory management?

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

AI Hentai Generator
Generate AI Hentai for free.

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

In this chapter, we will understand the Environment Variables, General Configuration, Database Configuration and Email Configuration in CakePHP.

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

To work with date and time in cakephp4, we are going to make use of the available FrozenTime class.

According to news from this website on September 3, Korean media etnews reported yesterday (local time) that Samsung Electronics and SK Hynix’s “HBM-like” stacked structure mobile memory products will be commercialized after 2026. Sources said that the two Korean memory giants regard stacked mobile memory as an important source of future revenue and plan to expand "HBM-like memory" to smartphones, tablets and laptops to provide power for end-side AI. According to previous reports on this site, Samsung Electronics’ product is called LPWide I/O memory, and SK Hynix calls this technology VFO. The two companies have used roughly the same technical route, which is to combine fan-out packaging and vertical channels. Samsung Electronics’ LPWide I/O memory has a bit width of 512

To work on file upload we are going to use the form helper. Here, is an example for file upload.

In this chapter, we are going to learn the following topics related to routing ?

CakePHP is an open-source framework for PHP. It is intended to make developing, deploying and maintaining applications much easier. CakePHP is based on a MVC-like architecture that is both powerful and easy to grasp. Models, Views, and Controllers gu

Validator can be created by adding the following two lines in the controller.
