根据参数包值定义模板

Mor*_*gan 2 c++ templates

此类中的方法使用一个索引序列,该索引序列包含覆盖整个data元组的索引序列(参数包中传递的每个参数的索引)。根据我看到的其他答案,我目前正在对我的方法进行模板化:

#include <tuple>
#include <memory>
#include <vector>

using std::tuple;

template <typename... Args>
class Foo
{
    protected:
        tuple<std::shared_ptr<std::vector<Args>>...> data;

    private:

        template<size_t...Is>
        void _clear_(std::index_sequence<Is...>) {
            (std::get<Is>(data)->clear(), ...);
        };

    public:

        void clear()
        { _clear_(std::index_sequence_for<Args...>()); };
};
Run Code Online (Sandbox Code Playgroud)

不过,这看起来很混乱。我想知道是否有一种方法可以Is在类级别范围内定义(或者,更一般地说,是否有更好的方法来做到这一点)。

Jar*_*d42 8

使用 C++17,您可以简单地使用std::apply

void clear()
{
    std::apply([](auto&... vs){ (vs.clear(), ...); }, data);
}
Run Code Online (Sandbox Code Playgroud)

我想知道是否有一种方法可以Is在类级别范围内定义

有额外的层:

template <typename Seq, typename...> class FooImpl;

template <std::size_t... Is, typename... Ts>
class FooImpl<std::index_sequence<Is...>, Ts...>
{
protected:
    std::tuple<std::shared_ptr<std::vector<Ts>>...> data;

public:
    void clear() { (std::get<Is>(data).clear(), ...); };
};

template <typename... Ts>
using Foo = FooImpl<std::make_index_sequence<sizeof...(Ts)>, Ts...>;
Run Code Online (Sandbox Code Playgroud)

  • 噢,天哪,这太聪明了。我从来没有想过像这样使用`std::apply`;我必须记住这一点。 (2认同)