为什么模板化的c++函数不能在Visual Studio 2013下编译
Why the templated c++ function does not compile under Visual Studio 2013
我正在尝试实现一个模板化函数,以便该函数仅接受某些特定类型的输入。我尝试了std::enable_if和std::is_base_of来实现这个目标。简化的代码如下所示。当启用c++11时,代码将使用clang++或g++编译和运行。但是当我用Visual Studio 2013编译它时,它总是显示could not deduce template argument for 'is_base_class'
。谁能告诉我为什么Visual Studio 2013不编译和如何解决这个问题?
#include <type_traits>
#include <map>
#include <unordered_map>
#include <iostream>
using namespace std;
template <class Type>
struct TypeWrapper {};
template <class T0, class T1>
struct CompoundType : public TypeWrapper<T0>, public TypeWrapper<T1> {};
template <class Type,
typename std::enable_if<
std::is_base_of<
TypeWrapper<Type>,
CompoundType<
std::map<typename Type::key_type, typename Type::mapped_type>,
std::unordered_map<typename Type::key_type, typename Type::mapped_type>
>
>::value
, Type
>::type* is_base_class = nullptr
>
void TemplatedFunction(Type map) {
std::cout << "Hello, world!" << std::endl;
}
int main(int argc, char *argv[])
{
std::unordered_map<int, double> a;
TemplatedFunction(a);
}
变通办法:
template <typename T,
typename K = typename T::key_type,
typename V = typename T::mapped_type>
struct rebind_to_unordered_map
{
using type = std::unordered_map<K, V>;
};
template <typename T,
typename K = typename T::key_type,
typename V = typename T::mapped_type>
struct rebind_to_map
{
using type = std::map<K, V>;
};
template <class Type>
typename std::enable_if<
std::is_base_of<
TypeWrapper<Type>,
CompoundType<
typename rebind_to_map<Type>::type,
typename rebind_to_unordered_map<Type>::type
>
>::value
, void
>::type
TemplatedFunction(const Type& ) {
std::cout << "Hello, world!" << std::endl;
}
或者
template <class Type,
typename K = typename Type::key_type,
typename V = typename Type::mapped_type,
typename std::enable_if<
std::is_base_of<
TypeWrapper<Type>,
CompoundType<std::map<K, V>, std::unordered_map<K, V>
>
>::value
, Type
>::type* is_base_class = nullptr
>
void TemplatedFunction(Type map) {
std::cout << "Hello, world!" << std::endl;
}
相关文章:
- Visual Studio 2015:Extern "C" 和 "export" 关键字
- 为cl.exe(Visual Studio代码)指定命令行C++版本
- 试图在visual studio上用C++创建一个桌面应用程序
- 如何在MS Visual Studio 2019中运行QT UI
- 如何使用Visual Studio 2017在C++中为参数化对象数组使用唯一指针
- Visual Studio Code - C++ Debugger 無法啟動
- Visual Studio 2019:插入多个C++风格的单行注释
- Visual Studio Code "undefined reference to `WinMain@16'"
- Visual studio代码重构似乎不起作用(例如,重命名符号-f2)
- Visual Studio中的函数声明和函数定义问题
- 如何指定我希望我的LIB链接到的DLL文件?-Visual Studio 2019
- Visual Studio mkl_link_tool.exe链接错误
- Visual Studio(或任何其他工具)能否将地址解释为调用堆栈(boost上下文)的开头
- 不同的Visual Studio版本中缺少.dll
- 用Visual Studio在C++中嵌入Julia
- Visual Studio 2017循环自动向量化问题
- 有没有办法在远程设备上打开和编辑visual Studio 2017解决方案
- 尝试使用继承和模板实现CRTP.Visual Studio正在生成编译器错误
- Visual Studio在尝试读取resource.txt文件时崩溃
- Visual Studio 2017 不允许我创建 C++ 专用模板