gpt4 book ai didi

c++ - "Ambiguous call to overloaded function"在 MSVC 编译器中带有枚举类

转载 作者:太空狗 更新时间:2023-10-29 20:34:42 26 4
gpt4 key购买 nike

我正在尝试使用值进行模板特化,一个化身是 bool,而另一个是枚举类。我和编译器纠缠了一天,也没能克服“对重载函数的模糊调用”错误。该代码丑陋且相当长,但这是一个简单的测试用例:

#include <iostream>

enum class Foo { Bar };
enum class Waldo { Fred };

template<Foo ARG, typename... _Types>
inline bool DOIT( _Types&&... _Args )
{
return true;
}

template<Waldo ARG, typename... _Types>
inline bool DOIT( _Types&&... _Args )
{
return false;
}

int main()
{
std::cout << DOIT<Foo::Bar>() << std::endl;
std::cout << DOIT<Waldo::Fred>() << std::endl;
return 0;
}

clang 3.8 和 gcc 4.8.3 都能顺利编译它,标准设置为 c++11,但 MSVC 一直向我发送 C2668 错误消息。

据我所知,枚举类的一个原因是为了避免隐式转换,但不确定。这是编译器错误,还是标准中的某些缺陷?

最佳答案

从技术上讲,您发布的代码是一个格式错误的程序,不需要诊断,因为您使用的标识符以 _ 开头,后跟一个大写字母。此类标识符由标准保留给编译器的实现者。

但这不是你的问题。


我见过一个案例,MSVC 在遵循标准时做对了,而 gcc 和 clang 都做错了。

最重要的是,这里的歧义是没有意义的。

你的编译器坏了。

一个可行的方法是:

template<Foo ARG, typename... Ts>
inline bool DOIT( std::integral_constant<Foo, ARG>, Ts&&... args )
{
return true;
}
template<Waldo ARG, typename... Ts>
inline bool DOIT( std::integral_constant<Waldo, ARG>, Ts&&... args )
{
return false;
}

int main()
{
std::cout << DOIT(std::integral_constant<Foo, Foo::Bar>{}) << std::endl;
std::cout << DOIT(std::integral_constant<Waldo, Waldo::Fred>{}) << std::endl;
return 0;
}

哪个works on this online MSVC compiler .

关于c++ - "Ambiguous call to overloaded function"在 MSVC 编译器中带有枚举类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46957603/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com