1

我有这样的课:

template<typename ...Els>
class Istr {
    std::tuple<Els...> Vals 
}

class Istr1 : public Istr<std::string> {
     void Do() { std::get<0>(Vals) = "Meh."; }
}

有没有办法定义我可以这样使用的功能模板?

Tok(0) = "Meh."
Istr i; i.Tok(0) = "Meh."

或者,如果不可能,像这样?

Tok<0>() = "Meh."

在我天真的方法中,我想出了一个错误的代码:

template<typename T>
T Tok(size_t i) { return std::get<i>(Vals); }

T当我使用它隐式实例化模板时,编译器实际上无法推断出类型。

4

2 回答 2

4
template<size_t i>
auto Tok() -> decltype( std::get<i>(Vals) ) {
    return std::get<i>(Vals);
}

现场演示

于 2016-01-09T18:32:24.927 回答
0
// Deduce `TI` thanks to the function argument.
template<typename TTuple, typename TI>
auto my_get(TTuple tuple, TI) 
{
    // `TI` needs to be an `std::integral_constant`.
    return std::get<TI{}>(tuple);
}

// `constexpr` variable template.
// `sz_v<0>` is `std::integral_constant<std::size_t, 0>{}`.
template<std::size_t TI>
constexpr std::integral_constant<std::size_t, TI> sz_v{};

// Example call.
// Results in `std::get<0>(some_tuple)`.
my_get(some_tuple, sz_v<0>);

如果将其定义为方法,则可以这样调用它:

struct some_struct
{ 
    std::tuple<...> some_tuple; 
};

some_struct s;
s.my_get(sz_v<0>);
于 2016-01-09T18:40:30.760 回答