在std::map中使用std::less无法编译
我无法理解为什么以下函数不能编译
#include <iostream>
#include <map>
int main(){
std::map<int, int, std::less<int>> myMap(std::less<int>());
myMap[2] = 2;
std::cout << myMap[2] << std::endl;
return 0;
}
错误信息如下——
std_less_check.cpp: In function ‘int main()’:
std_less_check.cpp:6:10: warning: pointer to a function used in arithmetic [-Wpointer-arith]
myMap[2] = 2;
^
std_less_check.cpp:6:14: error: assignment of read-only location ‘*(myMap + 2)’
myMap[2] = 2;
^
std_less_check.cpp:6:14: error: cannot convert ‘int’ to ‘std::map<int, int, std::less<int> >(std::less<int> (*)())’ in assignment
std_less_check.cpp:7:23: warning: pointer to a function used in arithmetic [-Wpointer-arith]
std::cout << myMap[2] << std::endl;
同时以下编译成功
#include <iostream>
#include <map>
int main(){
std::map<int, int, std::less<int>> myMap(std::less<int>{});
myMap[2] = 2;
std::cout << myMap[2] << std::endl;
return 0;
}
有人可以帮我解决这个问题吗?
回答
在第一个程序中,您有一个令人烦恼的解析。如果编译器可以将声明解析为变量或函数,它将选择将其解析为函数。
myMap 可以解析为函数声明。
它返回一个std::map<int, int, std::less<int>>.
它接受一个 type 参数std::less<int>(),它本身就是一个函数类型,它返回 astd::less<int>并且不接受任何参数。请注意,您实际上不能将函数类型作为参数;该类型实际上是一个指向函数的指针,该函数不接受任何参数并返回一个std::less<int>.
在第二个程序中,替换为()with{}解决了歧义。现在myMap不能再是一个函数声明,因此它声明了一个类型为 的变量std::map<int, int, std::less<int>>。