有效地操纵元组值?

时间:2017-02-12 17:33:13

标签: c++ tuples

我在C ++中没有使用std::tuple,我有以下元组:

std::tuple<int, int> range {0, 100};

这是我的mysql查询的范围:

prestmt_ = con_ -> prepareStatement("SELECT example_value FROM example_table  WHERE example_column = '0' LIMIT ?, ?");
prestmt_ -> setInt(1, std::get<0>(range));
prestmt_ -> setInt(2, std::get<1>(range));

我使用元组结构清楚地表明在函数的操作中两个整数耦合在一起。

我需要在每次查询后递增两个元组整数:

range = std::tuple<int, int>(std::get<0>(range) + 100, std::get<0>(range) + 100);

这种重新分配看起来很糟糕,并且不易阅读。有没有更好的方法来编辑这些元组值?

1 个答案:

答案 0 :(得分:2)

如果std::get<N>(x)左值,则

N会向x元组元素返回左值引用。因此,您可以说:

std::get<0>(range) += 100;
std::get<1>(range) += 100;

wandbox example

为了便于阅读,请使用功能 lambda

const auto increaseRange = [](auto& x, auto increment)
{
    std::get<0>(x) += increment;
    std::get<1>(x) += increment;
};

用法:

increaseRange(range, 100);

wandbox example

或者,考虑创建自己的integer_range课程,而不是使用std::tuple。它可以支持extend方法,它可以执行您想要的操作并拥有命名字段,与std::get<N>(...)相比,它更容易阅读:

template <typename T>
struct integer_range
{
    T _begin, _end;

    constexpr integer_range(T begin, T end) noexcept
        : _begin{begin}, _end{end} 
    {
        assert(_end >= _begin); // additional safety
    }

    void extend(T increment) noexcept
    {
        _begin += increment;
        _end += increment;
    }
};

wandbox example