检查以下代码:
string toLowerCase(const string& str) {
string res(str);
int i;
for (i = 0; i < (int) res.size(); i++)
res[i] = (char) tolower(res[i]);
return res;
}
class LeagueComparator
{
public:
bool operator()(const string& s1, const string& s2)
{
return toLowerCase(s1) < toLowerCase(s2);
}
};
int main()
{
set<string, LeagueComparator> leagues;
set<string, LeagueComparator>::iterator iter;
leagues.insert("BLeague");
leagues.insert("aLeague"); // leagues = {"aLeague", "BLeague"}
leagues.insert("ALeague");
for (iter = leagues.begin(); iter != leagues.end(); iter++)
cout << *iter << endl;
return 0;
}
输出是:
aLeague
BLeague
这让我感到震惊。我认为(并期待)输出将是:
aLeague
ALeague
BLeague
在执行之前leagues.insert("ALeague");
,leagues
包含"aLeague"
和"BLeague"
。我的问题是,在执行leagues.insert("ALeague");
时机器为什么要处理"ALeague" == "aleague"
?根据我的理解, 中没有元素"ALeague"
。leagues
所以"ALeague"
应该插入到leagues
. 比较器应确定放置位置"ALeague"
。
提前致谢。
PS:请不要因为我使用 C 风格演员而打我。:P 我懒得打字了static_cast
。