我有一个接收模板参数的函数。
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}});
}
是否可以在一个功能中执行此操作?假设容器参数为整数。
答案 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)
{
// ...
}
}
}