Итерация по параметру шаблона - PullRequest
0 голосов
/ 19 февраля 2020

У меня есть функция, которая получает параметр шаблона.

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 ]

6 голосов
/ 19 февраля 2020

Один пример:

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 голос
/ 19 февраля 2020

Это должно работать для вашего случая. Обратите внимание, что я использую черту, реализованную здесь в этом удивительном решении @ Jarod42 { ссылка }.

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)
       {...}
    }
}
0 голосов
/ 20 февраля 2020

С is_iterable чертами вы можете сделать:

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)
        {
            // ...
        }
    }
}
...