在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>>


以上是在std::map中使用std::less无法编译的全部内容。
THE END
分享
二维码
< <上一篇
下一篇>>