繁体   English   中英

可变参数模板函数:每个参数的参数编号

[英]Variadic template function: argument number for each argument

我正在使用C ++ 11中的可变函数模板,并且已经有了类似以下代码的基本思想:

void helper()
{
    std::cout << "No args" << std::endl;
}

template< typename T >
void helper( T&& arg )
{
    size_t n = 0;
    std::cout << "arg " << n << " = " << arg << std::endl;
    helper();
}

template< typename T, typename... Arguments >
void helper( T&& arg, Arguments&& ... args )
{
    size_t n = sizeof...( args );
    std::cout << "arg " << n << " = " << arg << std::endl;
    helper( args... );
}

但是,我想要的是参数编号(代码中的变量n)向上计数而不是向下计数。 我该如何优雅地做到这一点? 我可以编写一个包装函数来创建“隐藏的”参数计数,但是我觉得应该有一个更整洁的方法吗?

谢谢!

你的意思是这样吗? 我知道您在寻找什么,但是如果没有,我会毫不犹豫地放弃这个答案:

#include <iostream>
#include <utility>

void helper()
{
    std::cout << "no args" << std::endl;
}

template<size_t N, typename T>
void helper(T&& arg)
{
    std::cout << "arg " << N << " = " << arg << std::endl;
}

template<size_t N, typename T, typename... Args>
void helper(T&& arg, Args&&... args)
{
    helper<N>(std::forward<T>(arg));
    helper<N+1, Args...>(std::forward<Args>(args)...);
}

template<typename T, typename... Args>
void helper(T&& arg, Args&& ... args)
{
    helper<0>(std::forward<T>(arg), std::forward<Args>(args)... );
}

int main()
{
    helper();
    std::cout << '\n';

    helper("single");
    std::cout << '\n';

    helper("one", 2U);
    std::cout << '\n';

    helper(1,"two", 3.0, 4L);
    std::cout << '\n';

    return 0;
}

输出量

no args

arg 0 = single

arg 0 = one
arg 1 = 2

arg 0 = 1
arg 1 = two
arg 2 = 3
arg 3 = 4

现场观看

您可以执行以下操作: 实时示例

#if 1 // Not in C++11 // make_index_sequence
#include <cstdint>

template <std::size_t...> struct index_sequence {};

template <std::size_t N, std::size_t... Is>
struct make_index_sequence : make_index_sequence<N - 1, N - 1, Is...> {};

template <std::size_t... Is>
struct make_index_sequence<0u, Is...> : index_sequence<Is...> {};

#endif // make_index_sequence


namespace detail
{
    template<std::size_t...Is, typename... Ts>
    void helper(index_sequence<Is...>, Ts&&...args)
    {
        int dummy[] = {0, ((std::cout << "arg " << Is << " = " << args << std::endl), 0)...};
        static_cast<void>(dummy);
    }

}

void helper()
{
    std::cout << "No args" << std::endl;
}

template<typename ... Ts>
void helper(Ts&&... args)
{
    detail::helper(make_index_sequence<sizeof...(Ts)>(), std::forward<Ts>(args)...);
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM