在 std::map 中使用 std::less 无法编译

use of std::less in std::map does not compile

我无法理解为什么以下函数无法编译

#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可以解析为函数声明。

它returns一个std::map<int, int, std::less<int>>

它接受类型为 std::less<int>() 的参数,它本身是 returns 和 std::less<int> 的函数类型并且不接受任何参数。请注意,您实际上不能将函数类型作为参数;该类型实际上是一个指向不带参数的函数的指针,并且 returns a std::less<int>.


在第二个程序中,将 () 替换为 {} 解决了歧义。现在 myMap 不再是函数声明,因此它声明了一个 std::map<int, int, std::less<int>>.

类型的变量