Table of Contents
Micro-analysis of PHP performance
Home Backend Development PHP Tutorial Microscopic Analysis of PHP Performance_PHP Tutorial

Microscopic Analysis of PHP Performance_PHP Tutorial

Jul 12, 2016 am 09:08 AM
performance

Micro-analysis of PHP performance

1. Functions and commands related to performance analysis
1.1. Time measurement function
We usually use the time() function, but it returns the number of seconds. For internal performance analysis of a certain piece of code, the precision of seconds is not enough. So use the microtime function. The microtime function can return two forms, one is in the form of a string, and the other is in the form of a floating point number. However, it should be noted that by default, the precision returned is only 4 decimal places. In order to obtain higher accuracy, we need to configure precision.
The following are the results of using microtime.
    $start= microtime(true);
    echo $start."\n";
    $end = microtime(true);
    echo $end."\n";
    echo ($end-$start)."\n";
Copy after login

The output is:
bash-3.2# phptime.php
1441360050.3286
1441360050.3292
0.00053000450134277
And add a line in front of the code:
ini_set("precision", 16);
The output is:
bash-3.2# phptime.php
1441360210.932628
1441360210.932831
0.0002031326293945312
In addition to microtime internal statistics, you can also use getrusage to obtain user state events. In actual operations, the time command is also commonly used to calculate the running time of the entire program. By running it multiple times or modifying the code, different time lengths can be obtained to obtain differences in efficiency. The specific usage is: time phptime.php. After the program is completed, regardless of whether it ends normally and exits, there will be relevant statistics.
bash-3.2# time phptime.php
1441360373.150756
1441360373.150959
0.0002031326293945312
real 0m0.186s
user 0m0.072s
sys 0m0.077s
Because of the performance issues discussed in this article, we often analyze the gaps and trends after millions of calls. In order to avoid the existence of some time statistics code in the code, we will mostly use the time command later.
1.2. Memory usage related functions
There are two functions for analyzing memory usage: memory_ get_ usage and memory_ get_ peak_usage. The former can get the memory used at the time when the program is called, that is, the memory currently used, and the latter can get the memory used during the peak period so far. . The memory used is in bytes.
    $base_memory= memory_get_usage();
    echo "Hello,world!\n";
    $end_memory= memory_get_usage();
    $peak_memory= memory_get_peak_usage();

    echo $base_memory,"\t",$end_memory,"\t",($end_memory-$base_memory),"\t", $peak_memory,"\n";
Copy after login

The output is as follows:
bash-3.2# phphelloworld.php
Hello, world!
224400 224568 168 227424
As you can see, even if only one sentence is output in the middle of the program, plus variable storage, 168 bytes of memory are consumed.
For the same program, the memory usage of different PHP versions is not the same, or even very different.
   $baseMemory= memory_get_usage();
    class User
    {
    private $uid;
    function __construct($uid)
        {
    $this->uid= $uid;
        }
    }
    
    for($i=0;$i<100000;$i++)
    {
    $obj= new User($i);
    if ( $i% 10000 === 0 )
        {
    echo sprintf( '%6d: ', $i), memory_get_usage(), " bytes\n";
        }
    }
    echo "  peak: ",memory_get_peak_usage(true), " bytes\n";
Copy after login

In PHP 5.2, memory usage is as follows:
    [root@localhostphpperf]# php52 memory.php


    0: 93784 bytes
    10000: 93784 bytes
    ……
    80000: 93784 bytes
    90000: 93784 bytes
    peak: 262144 bytes
Copy after login

In PHP 5.3, memory usage is as follows
    [root@localhostphpperf]# phpmemory.php


    0: 634992 bytes
    10000: 634992 bytes
    ……
    80000: 634992 bytes
    90000: 634992 bytes
    peak: 786432 bytes
Copy after login

It can be seen that PHP 5.3 is more extensive in memory usage.
PHP 5.4 - 5.6 is almost the same, with some optimizations:
 [root@localhostphpperf]# php56 memory.php


    0: 224944 bytes
    10000: 224920 bytes
    ……
    80000: 224920 bytes
    90000: 224920 bytes
    peak: 262144 bytes
Copy after login

When PHP 7 is used in small quantities, the peak memory usage increases a lot.
  [root@localhostphpperf]# php7 memory.php


    0: 353912 bytes
    10000: 353912 bytes
    ……
    80000: 353912 bytes
    90000: 353912 bytes
    peak: 2097152 bytes
Copy after login

As you can see from the above, the PHP used above has a relatively good garbage collection mechanism. After 100,000 initializations, the memory usage does not increase with the increase in object initialization. PHP7 has the highest peak memory usage, reaching nearly 2M.
Let’s look at another example. Based on the above code, we add a line, which is the bold line as follows:
$obj->self = $obj;
The code is as follows:
    $baseMemory= memory_get_usage();
    class User
    {
    private $uid;
    function __construct($uid)
        {
    $this->uid= $uid;
        }
    }
    
    for($i=0;$i<100000;$i++)
    {
    $obj= new User($i);
    $obj->self = $obj;
    if ( $i% 5000 === 0 )
        {
    echo sprintf( '%6d: ', $i), memory_get_usage(), " bytes\n";
        }
    }
Copy after login

echo " peak: ",memory_get_peak_usage(true), " bytesn";

www.bkjia.comtruehttp: //www.bkjia.com/PHPjc/1053349.htmlTechArticleMicro-analysis of PHP performance 1. Functions and commands related to performance analysis 1.1. Time measurement function We usually use time ( ) function, but returns the number of seconds, for the internal part of a certain code...
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

Hot Article Tags

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

The difference between vivox100s and x100: performance comparison and function analysis The difference between vivox100s and x100: performance comparison and function analysis Mar 23, 2024 pm 10:27 PM

The difference between vivox100s and x100: performance comparison and function analysis

How to show hidden performance overlays in Windows 11 How to show hidden performance overlays in Windows 11 Mar 24, 2024 am 09:40 AM

How to show hidden performance overlays in Windows 11

Comparing the performance of Win11 and Win10 systems, which one is better? Comparing the performance of Win11 and Win10 systems, which one is better? Mar 27, 2024 pm 05:09 PM

Comparing the performance of Win11 and Win10 systems, which one is better?

Windows 10 vs. Windows 11 performance comparison: Which one is better? Windows 10 vs. Windows 11 performance comparison: Which one is better? Mar 28, 2024 am 09:00 AM

Windows 10 vs. Windows 11 performance comparison: Which one is better?

Kirin 8000 processor competes with Snapdragon series: Who can be king? Kirin 8000 processor competes with Snapdragon series: Who can be king? Mar 25, 2024 am 09:03 AM

Kirin 8000 processor competes with Snapdragon series: Who can be king?

Comparison of PHP and Go languages: big performance difference Comparison of PHP and Go languages: big performance difference Mar 26, 2024 am 10:48 AM

Comparison of PHP and Go languages: big performance difference

Performance comparison of different Java frameworks Performance comparison of different Java frameworks Jun 05, 2024 pm 07:14 PM

Performance comparison of different Java frameworks

The local running performance of the Embedding service exceeds that of OpenAI Text-Embedding-Ada-002, which is so convenient! The local running performance of the Embedding service exceeds that of OpenAI Text-Embedding-Ada-002, which is so convenient! Apr 15, 2024 am 09:01 AM

The local running performance of the Embedding service exceeds that of OpenAI Text-Embedding-Ada-002, which is so convenient!

See all articles