À propos des performances de la fonction magique PHP

小云云
Libérer: 2023-03-17 19:10:01
original
1315 Les gens l'ont consulté

Certaines personnes ne recommandent pas l'utilisation de "méthodes magiques". Certaines personnes se demandent si les méthodes magiques ne sont pas autorisées. En fait, ce n'est pas le cas. Cet article analysera avec vous les performances des fonctions magiques. .

Les suggestions d'optimisation sont des suggestions pour empêcher les gens d'en abuser et de les utiliser sans scrupules. Si vous pouvez comprendre ce qui est lent et ce qui est rapide lors de l'écriture de code, évitant ainsi certains appels de méthodes magiques inutiles, c'est l'effet recherché par ceci. suggestion d'optimisation

Douteux

  1. Les performances de la méthode magique sont-elles vraiment mauvaises ?

  2. Y a-t-il toujours un problème avec les performances des méthodes magiques en PHP7 ?

  3. Comment devrions-nous utiliser les méthodes magiques de manière raisonnable ?

Plan

Face à mes doutes, mon plan est :

  • Comparaison statistique entre utiliser la méthode magique et ne pas l'utiliser it Le décalage horaire d'exécution du script de la méthode magique

  • Le script est exécuté en continu n fois sous PHP5.6.26-1

  • La moyenne/minimum temps d'exécution statistique Valeur/Valeur maximale

  • Exécuter en continu le script n fois sous PHP7.0.12-2

  • Statistiques sur la moyenne/minimum/ temps d'exécution maximum Valeur

Actuellement, mes capacités personnelles sont limitées et je ne peux utiliser cette méthode que si vous avez un meilleur plan ou une meilleure suggestion, vous pouvez me le dire, merci, haha~<.>

Test

__construct

Tout d'abord, jetons un coup d'œil à l'expérience de la fonction constructeur __construct Le script php est le suivant :

<?php
/**
 * 魔术方法性能探索
 *
 * 构造函数
 *
 * @author TIGERB <https://github.com/TIGERB>
 */

require('./function.php');
if (!isset($argv[1])) {
    die('error: variable is_use_magic is empty');
}
$is_use_magic = $argv[1];

/**
 * 构造函数使用类名
 */
class ClassOne
{
    public function classOne()
    {
        # code...
    }
}

/**
 * 构造函数使用魔术函数__construct
 */
class ClassTwo
{
    public function __construct()
    {
        # code...
    }
}

$a = getmicrotime();
if ($is_use_magic === 'no_magic') {
    new ClassOne();
}else {
    new ClassTwo();
}
$b = getmicrotime();

echo  ($b-$a) . "\n";
Copier après la connexion

    PHP5.6 n'utilise pas les données de la méthode magique comme suit, unité microseconde μm
// PHP5.6中连续调用脚本10000次
sh test 10000 no_magic php5 construct

// 运行数据统计脚本
sh analysis ./logs/__construct_no_magic_php5.log 10000

// 结果
avg: 34μm
max: 483μm
min: 26μm
Copier après la connexion

    PHP5.6 utilise les données de la méthode magique comme suit, l'unité est la microseconde μm
// PHP5.6中连续调用脚本10000次
sh test 10000 magic php5 construct

// 运行数据统计脚本
sh analysis ./logs/__construct_magic_php5.log 10000

// 结果
avg: 28μm
max: 896μm
min: 20μm
Copier après la connexion

    PHP7.0 n'utilise pas la méthode magique. Les données sont les suivantes, l'unité est la microseconde μm
// PHP7.0中连续调用脚本10000次
sh test 10000 no_magic php construct

// 运行数据统计脚本
sh analysis ./logs/__construct_no_magic_php.log 10000

// 结果
avg: 19μm
max: 819μm
min: 13μm
Copier après la connexion

    PHP7.0 utilise le. données de la méthode magique comme suit, en microsecondes μm
// PHP7.0中连续调用脚本10000次
sh test 10000 magic php construct

// 运行数据统计脚本
sh analysis ./logs/__construct_magic_php.log 10000

// 结果
avg: 14μm
max: 157μm
min: 10μm
Copier après la connexion

Nous pouvons voir à partir des données ci-dessus :

Le temps d'exécution moyen d'un Le script utilisant __construct comme constructeur est plus rapide que d'utiliser le nom de la classe comme constructeur,

Probablement plus rapide de 5 à 6 microsecondes

, que ce soit en php5.6 ou php7.0. __call

Ensuite, jetons un coup d'œil à l'expérience __call. Le script php est le suivant :

<?php
/**
 * 魔术方法性能探索
 *
 * 构造函数
 *
 * @author TIGERB <https://github.com/TIGERB>
 */

require('./function.php');
if (!isset($argv[1])) {
    die('error: variable is_use_magic is empty');
}
$is_use_magic = $argv[1];

/**
 * 构造函数使用类名
 */
class ClassOne
{
    public function __construct()
    {
        # code...
    }

    public function test()
    {
        # code...
    }
}

/**
 * 构造函数使用魔术函数__construct
 */
class ClassTwo
{
    public function __construct()
    {
        # code...
    }

    public function __call($method, $argus)
    {
        # code...
    }
}

$a = getmicrotime();
if ($is_use_magic === 'no_magic') {
    $instance = new ClassOne();
    $instance->test();
}else {
    $instance = new ClassTwo();
    $instance->test();
}
$b = getmicrotime();

echo  ($b-$a) . "\n";
Copier après la connexion

    PHP5 .6 Les données sans utiliser la méthode magique sont les suivantes, l'unité est la microseconde μm
// PHP5.6中连续调用脚本10000次
sh test 10000 no_magic php5 call

// 运行数据统计脚本
sh analysis ./logs/__call_no_magic_php5.log 10000

// 结果
avg: 27μm
max: 206μm
min: 20μm
Copier après la connexion

    Les données avec PHP5.6 en utilisant la méthode magique est la suivante, l'unité Microseconde μm
// PHP5.6中连续调用脚本10000次
sh test 10000 magic php5 call

// 运行数据统计脚本
sh analysis ./logs/__call_magic_php5.log 10000

// 结果
avg: 29μm
max: 392μm
min: 22μm
Copier après la connexion

    PHP7.0 n'utilise pas le méthode magique. Les données sont les suivantes, l'unité est la microseconde μm
// PHP7.0中连续调用脚本10000次
sh test 10000 no_magic php call

// 运行数据统计脚本
sh analysis ./logs/__call_no_magic_php.log 10000

// 结果
avg: 16μm
max: 256μm
min: 10μm
Copier après la connexion

    PHP7.0 utilise les données de la méthode magique comme suit, en microsecondes μm
// PHP7.0中连续调用脚本10000次
sh test 10000 magic php call

// 运行数据统计脚本
sh analysis ./logs/__call_magic_php.log 10000

// 结果
avg: 18μm
max: 2459μm
min: 11μm
Copier après la connexion

Nous pouvons voir à partir des données ci-dessus :

Le temps d'exécution moyen d'un script utilisant __call est plus lent que cela sans l'utiliser,

environ 2 microsecondes

, peu importe en php5.6 ou php7.0. __callStatic

Ensuite, jetons un coup d'œil à l'expérience __callStatic Le script php est le suivant :

<?php
/**
 * 魔术方法性能探索
 *
 * 静态重载函数
 *
 * @author TIGERB <https://github.com/TIGERB>
 */

require('./function.php');
if (!isset($argv[1])) {
    die('error: variable is_use_magic is empty');
}
$is_use_magic = $argv[1];

/**
 * 存在test静态方法
 */
class ClassOne
{
    public function __construct()
    {
        # code...
    }

    public static function test()
    {
        # code...
    }
}

/**
 * 使用重载实现test
 */
class ClassTwo
{
    public function __construct()
    {
        # code...
    }

    public static function __callStatic($method, $argus)
    {
        # code...
    }
}

$a = getmicrotime();
if ($is_use_magic === 'no_magic') {
    ClassOne::test();
}else {
    ClassTwo::test();
}
$b = getmicrotime();

echo  ($b-$a) . "\n";
Copier après la connexion

<.>PHP5 .6 Les données sans méthode magique sont les suivantes, l'unité est la microseconde μm
// PHP5.6中连续调用脚本10000次
sh test 10000 no_magic php5 callStatic

// 运行数据统计脚本
sh analysis ./logs/__callStatic_no_magic_php5.log 10000

// 结果
avg: 25μm
max: 129μm
min: 19μm
Copier après la connexion

Les données avec PHP5 .6 L'utilisation de la méthode magique est la suivante, l'unité est la microseconde μm
// PHP5.6中连续调用脚本10000次
sh test 10000 magic php5 callStatic

// 运行数据统计脚本
sh analysis ./logs/__callStatic_magic_php5.log 10000

// 结果
avg: 28μm
max: 580μm
min: 20μm
Copier après la connexion

PHP7.0 n'utilise pas la méthode magique . Les données sont les suivantes, l'unité est la microseconde μm
// PHP7.0中连续调用脚本10000次
sh test 10000 no_magic php callStatic

// 运行数据统计脚本
sh analysis ./logs/__callStatic_no_magic_php.log 10000

// 结果
avg: 14μm
max: 130μm
min: 9μm
Copier après la connexion

PHP7.0 utilise les données de la méthode magique comme suit, en microsecondes μm
// PHP7.0中连续调用脚本10000次
sh test 10000 magic php callStatic

// 运行数据统计脚本
sh analysis ./logs/__callStatic_magic_php.log 10000

// 结果
avg: 14μm
max: 159μm
min: 10μm
Copier après la connexion
Nous pouvons voir à partir des données ci-dessus :

Le temps d'exécution moyen des scripts utilisant __callStatic en php5.6 est plus lent que de ne pas l'utiliser,

environ 3 microsecondes plus lent

 ; Le temps d'exécution moyen des scripts utilisant __callStatic dans php7.0 est à peu près égal à celui sans __callStatic;

__set

Ensuite, jetons un œil à l'expérience __set , le script php est le suivant :

<?php
/**
 * 魔术方法性能探索
 *
 * 设置私有属性__set
 *
 * @author TIGERB <https://github.com/TIGERB>
 */

require('./function.php');
if (!isset($argv[1])) {
    die('error: variable is_use_magic is empty');
}
$is_use_magic = $argv[1];

/**
 * 实现公共方法设置私有属性
 */
class ClassOne
{
    /**
     * 私有属性
     *
     * @var string
     */
    private $someVariable = 'private';

    public function __construct()
    {
        # code...
    }

    public function setSomeVariable($value = '')
    {
        $this->someVariable = $value;
    }
}

/**
 * 使用_set设置私有属性
 */
class ClassTwo
{
    /**
     * 私有属性
     *
     * @var string
     */
    private $someVariable = 'private';

    public function __construct()
    {
        # code...
    }

    public function __set($name = '', $value = '')
    {
        $this->$name = $value;
    }
}

$a = getmicrotime();
if ($is_use_magic === 'no_magic') {
    $instance = new ClassOne();
    $instance->setSomeVariable('public');
}else {
    $instance = new ClassTwo();
    $instance->someVariable = 'public';
}
$b = getmicrotime();

echo  ($b-$a) . "\n";
Copier après la connexion

PHP5.6 n'utilise pas la méthode magique. Les données sont les suivantes, en microsecondes μm
// PHP5.6中连续调用脚本10000次
sh test 10000 no_magic php5 set
// 运行数据统计脚本
sh analysis ./logs/__set_no_magic_php5.log 10000

// 结果
avg: 31μm
max: 110μm
min: 24μm
Copier après la connexion

PHP5.6 utilise les données de la méthode magique comme suit, en microsecondes μm
// PHP5.6中连续调用脚本10000次
sh test 10000 magic php5 set
// 运行数据统计脚本
sh analysis ./logs/__set_magic_php5.log 10000

// 结果
avg: 33μm
max: 138μm
min: 25μm
Copier après la connexion

PHP7.0 n'utilise pas la méthode magique Les données sont les suivantes, en microsecondes μm
// PHP7.0中连续调用脚本10000次
sh test 10000 no_magic php set
// 运行数据统计脚本
sh analysis ./logs/__set_no_magic_php.log 10000

// 结果
avg: 15μm
max: 441μm
min: 11μm
Copier après la connexion

PHP7.0 Les données utilisant la méthode magique sont les suivantes, en microsecondes μm
// PHP7.0中连续调用脚本10000次
sh test 10000 magic php set
// 运行数据统计脚本
sh analysis ./logs/__set_magic_php.log 10000

// 结果
avg: 17μm
max: 120μm
min: 11μm
Copier après la connexion
À partir des données ci-dessus, nous pouvons voir :

utilise __set Le temps d'exécution moyen du script est plus lent que sans lui,

environ 2 microsecondes

, que ce soit en php5.6 ou php7.0.

__get

Ensuite, jetons un coup d'œil à l'expérience __get. Le script php est le suivant :

<?php
/**
 * 魔术方法性能探索
 *
 * 读取私有属性__get
 *
 * @author TIGERB <https://github.com/TIGERB>
 */

require('./function.php');
if (!isset($argv[1])) {
    die('error: variable is_use_magic is empty');
}
$is_use_magic = $argv[1];

/**
 * 实现公共方法获取私有属性
 */
class ClassOne
{
    /**
     * 私有属性
     *
     * @var string
     */
    private $someVariable = 'private';

    public function __construct()
    {
        # code...
    }

    public function getSomeVariable()
    {
        return $this->someVariable;
    }
}

/**
 * 使用_get获取私有属性
 */
class ClassTwo
{
    /**
     * 私有属性
     *
     * @var string
     */
    private $someVariable = 'private';

    public function __construct()
    {
        # code...
    }

    public function __get($name = '')
    {
        return $this->$name;
    }
}

$a = getmicrotime();
if ($is_use_magic === 'no_magic') {
    $instance = new ClassOne();
    $instance->getSomeVariable();
}else {
    $instance = new ClassTwo();
    $instance->someVariable;
}
$b = getmicrotime();

echo  ($b-$a) . "\n";
Copier après la connexion

PHP5 .6 Les données sans utiliser la méthode magique sont les suivantes, l'unité est la microseconde μm
// PHP5.6中连续调用脚本10000次
sh test 10000 no_magic php5 get
// 运行数据统计脚本
sh analysis ./logs/__get_no_magic_php5.log 10000

// 结果
avg: 28μm
max: 590μm
min: 20μm
Copier après la connexion

Les données avec PHP5.6 en utilisant la méthode magique est la suivante, l'unité Microseconde μm
    // PHP5.6中连续调用脚本10000次
    sh test 10000 magic php5 get
    // 运行数据统计脚本
    sh analysis ./logs/__get_magic_php5.log 10000
    
    // 结果
    avg: 28μm
    max: 211μm
    min: 22μm
    Copier après la connexion

     

    • PHP7.0不使用魔术方法数据如下,单位微秒μm

    // PHP7.0中连续调用脚本10000次
    sh test 10000 no_magic php get
    // 运行数据统计脚本
    sh analysis ./logs/__get_no_magic_php.log 10000
    
    // 结果
    avg: 16μm
    max: 295μm
    min: 10μm
    Copier après la connexion

     

    • PHP7.0使用魔术方法数据如下,单位微秒μm

    // PHP7.0中连续调用脚本10000次
    sh test 10000 magic php get
    // 运行数据统计脚本
    sh analysis ./logs/__get_magic_php.log 10000
    
    // 结果
    avg: 19μm
    max: 525μm
    min: 12μm
    Copier après la connexion

     

    通过上面的数据我们可以看出:

    在php5.6中使用__get的脚本执行的平均时间是要大致等于不使用__get的;在php7.0中使用__get的脚本执行的平均时间是要慢于不使用, 大概慢3微秒

    结语

    这里主要测试了__construct(), __call(), __callStatic(), __get(), __set()这五个常用的且可有其他实现方式代替的魔法函数。通过上面的测试再回来解答我的疑惑

    1. 魔术方法真的性能比较差吗?

    答:除了使用__construct之外,这里使用其他的魔法方法的时间大致慢10微妙以内。

    1. PHP7里使用魔术方法的性能还是存在问题吗?

    答:在PHP7中使用与不使用魔术方法之间的差异和在PHP5.6中近乎一致。

    1. 我们应该如何合理的使用魔术方法?

    答:通过整个测试我们可以看出使不使用魔法方法这之间的执行时间差异大致都是在10微妙以内的,所以如果魔法方法可以很好的节省我们的开发成本和优化我们的代码结构,我们应该可以考虑牺牲掉这不到10微妙。而__construct是要快的,所以使用__construct应该没什么异议。

    以上内容就是关于PHP 魔法函数性能分析,希望对大家有帮助。

    相关推荐:

    php中关于魔法函数以及魔法常量的使用详解

    详解PHP魔法函数性能的示例代码

    PHP魔法函数应用详解_PHP教程

    Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

    Étiquettes associées:
    source:php.cn
    Déclaration de ce site Web
    Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
    Tutoriels populaires
    Plus>
    Derniers téléchargements
    Plus>
    effets Web
    Code source du site Web
    Matériel du site Web
    Modèle frontal
    À propos de nous Clause de non-responsabilité Sitemap
    Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!