"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > La définition de méthodes via un constructeur en JavaScript crée-t-elle des copies de fonctions en double ?

La définition de méthodes via un constructeur en JavaScript crée-t-elle des copies de fonctions en double ?

Publié le 2024-11-14
Parcourir:229

Does Defining Methods via Constructor in JavaScript Create Duplicate Function Copies?

Implications sur les performances de la définition de méthodes via un prototype ou un constructeur en JavaScript

En JavaScript, deux approches existent pour créer des « classes » avec des fonctions publiques : en utilisant le prototype ou le constructeur. La méthode 1 attribue des fonctions aux instances via le constructeur, tandis que la méthode 2 utilise le prototype pour partager des fonctions entre toutes les instances.

Bien que la méthode 2 soit souvent considérée comme plus efficace, priver les instances de variables d'instance privées constitue un inconvénient majeur. . Cependant, la création apparente de copies de fonctions en double pour chaque instance par la méthode 1 se produit-elle réellement dans la pratique ?

Preuves empiriques de JsPerf Benchmark

L'analyse comparative JsPerf suggère que la méthode 2 (prototype ) surpasse en effet la Méthode 1 (constructeur) en terme de rapidité.

Pratique Implications

Bien que cette différence soit évidente dans les benchmarks, sa pertinence dans les applications du monde réel est discutable. Même dans les scénarios comportant un nombre important d'instanciations d'objets (par exemple, 10 000 par image), il est peu probable que cette micro-optimisation réduise les goulots d'étranglement des performances.

Recommandations

En cas d'optimisation la performance est cruciale, il est conseillé de déclarer les méthodes via le prototype. Sinon, la méthode 1 offre une plus grande flexibilité et adhère aux conventions courantes de programmation orientée objet. De plus, l'utilisation de propriétés privées indiquées par un préfixe de soulignement (par exemple, _process()) améliore l'encapsulation et décourage la modification directe.

Dernier tutoriel Plus>

Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.

Copyright© 2022 湘ICP备2022001581号-3