替换函数包装器

时间:2018-01-30 14:01:47

标签: c++ code-duplication

我有一个管理两个连接(源和目标)的C ++类。连接上的每个操作都是两阶段,准备阶段和提交阶段。我希望在两个连接上执行一些操作并使用几乎相同的参数。

即,

mngr::init_conn(int var1, int var2, int var3)
{
    m_conn.prepare_init(source_id, var1, var2, var3);
    m_conn.commit();

    m_conn.prepare_init(target_id, var1, var2, var3);
    m_conn.commit();
}

mngr::update_conn(int var1, int var2)
{
    m_conn.prepare_update(source_id, var1, var2);
    m_conn.commit();

    m_conn.prepare_update(target_id, var1, var2);
    m_conn.commit();
}

请注意,相同的连接对象管理源和目标连接。连接对象不是我的,我不允许更改它。

有没有办法删除方法中的代码重复?我想要包装方法,但我想知道是否有一种方法没有为每个函数生成函数包装器

我想到了这样的事情:

mngr::init_wrapper(ID id,int var1, int var2, int var3)
{
    m_conn.prepare_init(id, var1, var2, var3);
    m_conn.commit();
}

mngr::update_wrapper(ID id,int var1, int var2)
{
    m_conn.prepare_update(id, var1, var2);
    m_conn.commit();
}

mngr::init_conn(int var1, int var2, int var3)
{
    init_wrapper(source_id, var1, var2, var3);
    init_wrapper(target_id, var1, var2, var3);
}

mngr::update_conn(int var1, int var2)
{
    update_wrapper(source_id, var1, var2);
    update_wrapper(target_id, var1, var2);
}

您是否有关于不为每个函数生成函数包装器的方法的想法?

1 个答案:

答案 0 :(得分:1)

范围for超过std::initializer_list

mngr::init_conn(int var1, int var2, int var3)
{
    for (auto id : {source_id, target_id})
    {
        m_conn.prepare_init(id, var1, var2, var3);
        m_conn.commit();
    }
}

如果您需要更改id内的for,则应将其更改为auto &id,否则将丢弃更改。