Comment optimiser ce code ? Le patron a dit qu'il devrait être converti en structure de données cartographiques ES6. Ma conversion est peut-être erronée et elle semble être plus lente
C'est l'optimisation que j'ai faite, elle semble être plus lente S'il vous plaît, donnez-moi quelques conseils
Utilisez
filter()
确实可以一句话搞定,但是,效率不高。其实可以用find
(voir MDN)Malheureusement, IE ne prend pas en charge
find()
, il y a donc un Polyfill vers la fin de la documentation MDN.Si vous utilisez map pour l'implémenter, vous n'avez pas besoin d'utiliser ES6 Map, car l'objet natif prend en charge les clés de type chaîne, mais quelle que soit la manière dont il est implémenté, la conversion de cette carte devrait prendre
getServiceTypeName
之外进行。因为转换的过程比你写的for ... of
plus de temps.objToStrMap ne doit être initialisé qu'une seule fois. Vous l'initialisez à chaque fois dans la boucle, ce qui sera plus lent.
Instructions supplémentaires
...
Convertissez-le d'abord en une structure de carte avec des paires clé-valeur nom : Id. Ensuite, vous pouvez utiliser directement le nom pour obtenir l'identifiant correspondant. Vous n'avez pas du tout compris le sens de la méthode qu'il vous a expliquée.
Convertissez d'abord le tableau de types en une structure de carte, puis récupérez-le via map.get(code). Pas besoin de traverser.
Dans
fonction, vous pouvez écrire comme ceci
let result = serviceTypeList.map((val)=> val.typeId === code);
retVal = result.name;
Juste une demi-ligne de code
L'opération de filtrage en boucle n'est pas lente.
Quelle solution de conversion en carte doit prendre en compte le coût de la conversion elle-même
L'implémentation de la carte fournie avec certains langages utilise des tableaux lorsque la collection est petite, éliminant ainsi le besoin d'opérations de hashcode et améliorant l'efficacité