Maison > interface Web > js tutoriel > Huit méthodes et analyse des performances de la traversée du tableau js (avec code)

Huit méthodes et analyse des performances de la traversée du tableau js (avec code)

不言
Libérer: 2018-07-26 17:55:01
original
4278 Les gens l'ont consulté

Dans l'article précédent, nous avons présenté un résumé et une analyse des performances de 11 méthodes d'échange de valeurs entre deux variables en js Aujourd'hui, je vais partager avec vous huit méthodes et performances de traversée de tableaux js. Analyse, sans plus tarder, regardons directement le contenu.

Plusieurs méthodes de parcours de tableau JS

Le parcours de tableau JS est essentiellement pour, forin, foreach, forof, map, etc. Certaines méthodes sont présentées ci-dessous. méthodes de traversée utilisées et effectuer une analyse et une comparaison des performances

Le premier type : traversée de tableau de boucles ordinaire

Le code est le suivant :

for(j = 0; j < arr.length; j++) {
   
}
Copier après la connexion

Brève description :
Le plus simple et le plus fréquemment utilisé Bien que les performances ne soient pas faibles, il y a encore de la place pour l'optimisation

Le deuxième type : version optimisée du parcours de tableau de boucles for.

Le code est le suivant :

for(j = 0,len=arr.length; j < len; j++) {
   
}
Copier après la connexion

Brève description :
Utilisez des variables temporaires pour mettre en cache la longueur afin d'éviter d'obtenir à plusieurs reprises la longueur du tableau. L'effet d'optimisation est uniquement. lorsque le tableau est grand, ce sera plus évident.

Cette méthode est fondamentalement la plus performante parmi toutes les méthodes de traversée de boucles

Le troisième type : version affaiblie de la traversée de tableaux de boucles for

Le code est comme suit :

for(j = 0; arr[j]!=null; j++) {
   
}
Copier après la connexion

Brève description :
Cette méthode est en fait strictement une boucle for, mais elle n'utilise pas le jugement de longueur, mais utilise la variable elle-même pour juger

In En fait, les performances de cette méthode sont bien inférieures à celles de la boucle for ordinaire

La quatrième méthode : parcours de tableau de boucles foreach

Le code est le suivant :

arr.forEach(function(e){  
   
});
Copier après la connexion

Brève description :
La boucle foreach fournie avec le tableau est utilisée plus fréquemment et ses performances sont en fait plus faibles que la boucle for ordinaire

Le cinquième type : traversée de tableau de variantes foreach

Le code est le suivant :

Array.prototype.forEach.call(arr,function(el){  
   
});
Copier après la connexion

Brève description :
Étant donné que foreach est livré avec le type Array, certains types autres que ce type ne peuvent pas être utilisé directement (comme NodeList), c'est donc cette variante qui permet à des tableaux similaires d'avoir des fonctionnalités foreach.

Les performances réelles sont plus faibles que celles d'un foreach ordinaire

Sixième type : traversée d'un tableau de boucles forin

Le code est le suivant :

for(j in arr) {
   
}
Copier après la connexion

Brève description :
Beaucoup de gens aiment utiliser cette boucle, mais en fait, après analyse et tests, parmi les nombreuses méthodes de parcours de boucle

son efficacité est la plus faible

Septième type : parcours de carte

Le code est le suivant :

arr.map(function(n){  
   
});
Copier après la connexion

Brève description :
Cette méthode est également largement utilisée bien qu'elle soit plus élégante. à utiliser, l'efficacité réelle n'est pas aussi bonne que foreach

Le huitième type : forof traversal (nécessite le support ES6)

Le code est le suivant :

for(let value of arr) {  
   
});
Copier après la connexion

Brève description :
Cette méthode est utilisée dans es6. Ses performances sont meilleures que celles du forin, mais elles ne sont toujours pas aussi bonnes que la boucle for ordinaire

Comparaison des performances de. diverses méthodes de traversée

Les différentes méthodes énumérées ci-dessus ont été analysées comparativement une par une. Fondamentalement, la conclusion qui peut être tirée est la suivante :

La boucle for ordinaire est la plus élégante <.>

( PS : Tous les codes ci-dessus n'effectuent que des boucles vides, il n'y a pas de code d'exécution interne dans la boucle, ils analysent uniquement le temps de chaque boucle)

Captures d'écran de comparaison des performances

Résultats de l'analyse 1

Les données dans la capture d'écran ci-dessous sont la conclusion tirée après l'avoir exécutée 100 fois dans Chrome (prend en charge es6)

(exécuter 10 fois à chaque fois, 10 cycles au total, Les résultats d'analyse obtenus)

Huit méthodes et analyse des performances de la traversée du tableau js (avec code)

On voit que la boucle forin est la le plus lent. La boucle for ordinaire optimisée est la plus rapide

Résultat de l'analyse 2

Les données de capture d'écran suivantes sont la conclusion tirée après l'avoir exécutée 1000 fois dans Chrome (prend en charge es6)

(à chaque fois, exécutez 100 fois, 10 cycles au total, et obtenez les résultats de l'analyse) JS traversant des tableaux et exemple de tableau d'impression compétences d'analyse_javascript

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