Comparateurs transparents : capacités de recherche améliorées dans les conteneurs associatifs
Dans C 14, un changement important a été introduit dans les conteneurs associatifs. Comme indiqué dans [associative.reqmts]/13, les modèles de fonctions membres find, count, lower_bound, upper_bound et equal_range ne participent à la résolution de surcharge que si le type Compare::is_transparent existe.
Objectif de Comparateurs transparents
Le but de rendre un comparateur « transparent » est d'étendre la fonctionnalité de recherche des conteneurs associatifs. En permettant aux comparateurs d'être transparents, les développeurs peuvent utiliser des types comparables à la clé du conteneur plutôt que d'être contraints d'utiliser le type de clé lui-même. Cela permet des scénarios de recherche plus flexibles et efficaces.
Mise en œuvre et utilisation
C 14 introduit des modèles de bibliothèque tels que std::less qui facilitent la création de comparateurs transparents :
template <class T = void> struct less { // ... typedef *unspecified* is_transparent; }; template <> struct less<void> { // ... typedef *unspecified* is_transparent; };
Dans cet exemple, std::set
Impact sur les conteneurs associatifs
Ce changement n'a notamment pas d'impact sur le fonctionnement par défaut des conteneurs standards prêts à l'emploi. Ils continueront à se comporter comme ils l'ont toujours fait, en utilisant leur type de clé comme principal critère de comparaison.
Cependant, en utilisant l'attribut std::less<> comparateur transparent ou d'autres alternatives compatibles, les développeurs peuvent débloquer la fonctionnalité améliorée de recherche hétérogène dans des conteneurs associatifs. Cela leur permet d'effectuer des comparaisons en utilisant des types qui peuvent différer du type de clé du conteneur, augmentant ainsi la flexibilité et la polyvalence.
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!