Instanceof Performance en Java
Lorsqu'ils traitent de l'héritage en Java, les développeurs sont souvent confrontés à la question de savoir si l'utilisation de l'opérateur instanceof a un impact sur les performances. Bien qu'il soit entendu que la conception orientée objet s'efforce de minimiser les instances d'utilisation, cette requête se concentre uniquement sur ses implications en termes de performances.
Dans un scénario typique, une classe de base avec plusieurs sous-classes existe et une fonction opérant sur la classe de base effectue des vérifications d'instance sur chaque sous-classe. Une approche alternative consiste à utiliser une primitive entière « ID de type » avec un masque de bits pour la catégorisation des sous-classes. Cette approche soulève la question de savoir si la JVM optimise instanceof pour une vitesse supérieure.
Résultats de l'analyse comparative
Pour évaluer les différentes options de mise en œuvre, un programme de référence a été créé. Les options comprenaient :
Le benchmark mesure le temps d'exécution moyen de chaque option sur 10 000 itérations.
Analyse des performances
Les résultats indiquent que dans Java 1.8, instanceof est l'approche la plus rapide, suivie de près par getClass(). Voici un résumé :
Operation | Runtime | Relative to instanceof |
---|---|---|
INSTANCEOF | 39,598 ns/op | 100.00% |
GETCLASS | 39,687 ns/op | 100.22% |
TYPE | 46,295 ns/op | 116.91% |
OO | 48,078 ns/op | 121.42% |
Conclusion
Dans Java 1.8, instanceof représente l'approche la plus rapide pour vérifier les instances de classe. Bien que getClass() ait des performances comparables, des approches alternatives telles que TYPE et l'héritage orienté objet entraînent une légère pénalité de performances. Les développeurs recherchant des performances optimales doivent donner la priorité à instanceof par rapport aux autres options.
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!