gpt4 book ai didi

c++ - 如何根据容器的元素类型启用模板函数实例化

转载 作者:行者123 更新时间:2023-11-28 02:11:45 24 4
gpt4 key购买 nike

我已经定义了容器检查结构及其实例:

template <typename Container>
struct is_container : std::false_type { };

template<typename... Ts>
struct is_container<std::vector<Ts...>> : std::true_type { };

template<typename... Ts>
struct is_container<std::deque<Ts...>> : std::true_type { };

//... all other STL containers

它非常有效,对于像这样的函数模板:

template<typename T, typename = typename std::enable_if<is_container<T>::value>::type>
void container_fun(const T& cont)
{
std::cout << "argument is clearly a container!" << std::endl;
}

但是现在,我想允许根据容器的元素类型进行实例化。好吧,类似的东西:

template<template<typename ...> class C , // container
typename T, // container's element
typename = typename std::enable_if<is_container<T>::value>::type> // permission
void is_element_container(const C<T>& cont)
{
std::cout << "container's elemement is also a container!" << std::endl;
}

但是,这会导致错误:

.../main.cpp:10: error: no matching function for call to 'is_element_container(std::deque<int, std::allocator<int> >&)'
is_element_container(deq);
^
.../containers.h:36: error: no type named 'type' in 'struct std::enable_if<false, void>'
typename = typename std::enable_if<is_container<T>::value>::type>
^

然而,在删除第三个模板参数(权限检查)之后:

template<template<typename ...> class C , // container
typename T> // container's element

程序正常编译,函数打印输出。为什么会这样?

最佳答案

根据您的代码is_element_container需要 C成为一个以容器作为模板参数的容器。

但是编译器提示 std::deque<int>不是容器的容器,它确实不是。

就像你想做的那样

std::deque<int> cont;
is_element_container(cont);

但是你好像很想做

std::deque<std::deque<int>> cont;
is_element_container(cont);

这将允许模板推导正确工作。

关于c++ - 如何根据容器的元素类型启用模板函数实例化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35436793/

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