遍历模板参数

时间:2020-02-19 10:46:03

标签: c++ templates stl generic-programming

我有一个接收模板参数的函数。

template<class Container>
void function(const Container& object)
{
     //here i want to iterate through object and print them
}

int main()
{
     function(std::vector<int>{1,3,6,7});
     function(std::vector<std::vector<int>>{{1,2,3},{2,5,7}});
}

是否可以在一个功能中执行此操作?假设容器参数为整数。

3 个答案:

答案 0 :(得分:6)

一个例子:

template<class T>
void print(T const& object) {
    std::cout << object;
}

template<class... Args>
void print(std::vector<Args...> const& container) {
    for(auto const& element : container) {
        print(element);
        std::cout << ' ';
    }
    std::cout << '\n';
}

int main() {
     print(std::vector<int>{1,3,6,7});
     print(std::vector<std::vector<int>>{{1,2,3},{2,5,7}});
}

答案 1 :(得分:1)

这应该适合您的情况。请注意,我使用的是@ Jarod42 https://stackoverflow.com/a/29634934/8192043的惊人解决方案中实现的特征。

template<template<typename ...> typename C, typename D, typename ... Others>
void function(const C<D, Others...> &object)
{
    if constexpr(is_iterable<D>::value)
    {
       for(const auto& v : object)
       {
           for (const auto& w : v)
           {...}
       }
    }
    else
    {
       for (const auto& w : object)
       {...}
    }
}

答案 2 :(得分:0)

使用is_iterable traits,您可以这样做:

template<typename Container>
void function(const Container& object)
{
    if constexpr(is_iterable<std::decay_t<*object.begin()>>::value)
    {
       for(const auto& v : object)
       {
           function(v); // recursive call
       }
    }
    else
    {
        for (const auto& w : object)
        {
            // ...
        }
    }
}