Ich versuche std::string
s in einer Gebietsschema-abhängigen Weise zu vergleichen.locale-abhängige Reihenfolge für std :: string
Für gewöhnliche C-Strings, habe ich strcoll
gefunden, das ist genau das tut, was ich will, nach std::setlocale
#include <iostream>
#include <locale>
#include <cstring>
bool cmp(const char* a, const char* b)
{
return strcoll(a, b) < 0;
}
int main()
{
const char* s1 = "z", *s2 = "å", *s3 = "ä", *s4 = "ö";
std::cout << (cmp(s1,s2) && cmp(s2,s3) && cmp(s3,s4)) << "\n"; //Outputs 0
std::setlocale(LC_ALL, "sv_SE.UTF-8");
std::cout << (cmp(s1,s2) && cmp(s2,s3) && cmp(s3,s4)) << "\n"; //Outputs 1, like it should
return 0;
}
jedoch tun, würde Ich mag auch dieses Verhalten haben für std::string
. Ich konnte überlastete nur operator<
so etwas wie
bool operator<(const std::string& a, const std::string& b)
{
return strcoll(a.c_str(), b.c_str());
}
zu tun, aber dann müsste ich über Code kümmern mit std::less
und std::string::compare
, so dass es nicht richtig anfühlen.
Gibt es eine Möglichkeit, diese Art der Sortierung für Strings nahtlos zu arbeiten?
Das ist praktisch. Es macht die Standardsammlungen ohne Aufwand möglich. – CAdaker