std :: get为自己的类,以元组为成员

时间:2015-01-28 15:57:31

标签: c++ templates std

我有一个这样的课程:

 template<typename ... TTypes>
 class Composite {
 public:
     std::tuple<TTypes...> &getRefValues() { return values; }   
 private:
     std::tuple<TTypes...> values;
 };

我可以为我的类Composite定义std::get吗?它基本上应该调用已定义的std::get私有元组值。

当返回类型已知时(例如对于int数组成员),我能够实现自定义的get函数,但我不知道如何在返回类型可以是任意类型时实现get(取决于元组值的元组类型?)

2 个答案:

答案 0 :(得分:1)

您可以这样做:

template <std::size_t I, typename... Ts>
auto get(Composite<Ts...>& composite)
-> decltype(std::get<I>(composite.getRefValues()))
{
    return std::get<I>(composite.getRefValues());
}

注意:在C ++ 14中,您可以省略-> decltype(..)部分。

答案 1 :(得分:1)

为了完整性,这是我的解决方案。谢谢大家:

template<typename ... TTypes>
class Composite {
public:
    Composite(TTypes... t) {
        std::tuple<TTypes...> tuple(t...);
        values = tuple;
    } 

    std::tuple<TTypes...> &getRefValues() { return values; }    
private:
    std::tuple<TTypes...> values;
};

namespace std {
template<size_t I, typename ... TTypes>
    auto get(Composite<TTypes ...> &t) -> typename std::tuple_element<I, std::tuple<TTypes...>>::type { 
        return std::get<I>(t.getRefValues());
    }
}

int main() {
    Composite<int, char, double> c(13, 'c', 13.5);
    std::cout << std::get<0>(c) << std::endl;
    std::cout << std::get<1>(c) << std::endl;
    std::cout << std::get<2>(c) << std::endl;

    return 0;
}