Maison > Article > développement back-end > print vs echo, lequel est le plus rapide ?
Comme la plupart d'entre nous, j'en ai marre de lire des articles de blog sur des micro-optimisations dénuées de sens comme le remplacement de print par echo, ++$i par $i++, ou des guillemets doubles par des guillemets simples. Pourquoi ? Parce que 99,999999 % du temps, cela n'a pas d'importance. Vous feriez mieux d'installer un accélérateur PHP comme APC ou d'ajouter ces index manquants dans les colonnes de la base de données ou d'essayer d'éviter 1000 requêtes de base de données sur la page d'accueil.
Supposons que vous vouliez vraiment connaître la réponse à cette question. Plutôt que d'essayer d'écrire un script et de l'exécuter un million de fois pour trouver la vitesse la plus rapide, je préfère vous montrer quelques outils intéressants qui pourraient parfois vous être utiles car ils vous permettent de mieux comprendre ce que vous écrivez du code PHP.
Entrez VLD, le "Vulcan Logic Disassembler". VLD est écrit par Derrick Rethans, et comme vous pouvez le voir sur la page d'accueil de VLD, il "se connecte au moteur Zend et sauvegarde tous les opcodes (unités d'exécution) du script".
Installer VLD est très simple. Téléchargez la dernière version et installez-la comme n'importe quelle autre extension PHP :
$ phpize $ ./configure $ sudo make install
Activez l'extension en php. fichier ini :
extension=vld.so
Il est temps de regarder sous le capot. Créez deux fichiers simples, l'un en utilisant echo et l'autre en utilisant print :
// print.php
Exécutez ces scripts à partir de la ligne de commande en utilisant -d vld. Le paramètre activate=1 active la sortie VLD. Regardons les opcodes générés par ces scripts :
$ php -d vld.active=1 print.php
-
number of ops: 4 compiled vars: none line # op fetch ext return operands ------------------------------------------------------------------------------- 1 0 PRINT ~0 'foo' 1 FREE ~0 2 2 RETURN 1 3* ZEND_HANDLE_EXCEPTION
-
$ php -d vld.active=1 echo.php
-.
number of ops: 3 compiled vars: none line # op fetch ext return operands ------------------------------------------------------------------------------- 1 0 ECHO 'foo' 2 1 RETURN 1 2* ZEND_HANDLE_EXCEPTION
Avez-vous remarqué la différence ? Oui, print utilise également un opcode car il renvoie réellement quelque chose. Nous pouvons conclure que l'écho est plus rapide que l'impression. Mais un opcode ne coûte rien, même si un script comporte des centaines d'appels à imprimer.
Comme print renvoie toujours 1, vous pouvez faire les choses intéressantes suivantes, qui ne sont pas possibles en écho : Nombre d'opcodes ? Essayez ceci :
[php]
Je l'ai essayé avec un nouveau WordPress installation. Le script s'arrête avant de se terminer par une "Erreur de bus" sur mon ordinateur portable, mais le nombre d'opcodes a dépassé 2,3 millions.
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!