Idée fausse de la conclusion originale
Initialement, un benchmark défectueux a suggéré que l'itération std :: array était plus rapide que l'itération std :: vector. Cependant, après avoir corrigé le benchmark, il est apparu que std::vector était nettement plus rapide.
Mise en œuvre du benchmark
Pour garantir l'exactitude, le benchmark a utilisé plusieurs améliorations :
Résultats et explications
Les résultats de référence ont révélé que l'itération std::vector s'est terminée en environ 30 millisecondes, tandis que l'itération std::array a pris environ 99 millisecondes.
La disparité vient du comportement de la page mémoire. Dans le benchmark, le std::array se trouvait dans la section .bss de l'exécutable (avec zéro initialisation), donc ses pages mémoire n'étaient pas chargées dans l'espace d'adressage du processus. À l'inverse, le std::vector avait été alloué et rempli de zéros, ce qui entraînait la présence de la page.
Solution
Pré-erreur des pages std::array par zéro -remplir ou utiliser mlock() sous Linux amène ses pages dans l'espace d'adressage, assimilant sa vitesse d'itération à celle de std::vector.
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!