7

我有一个“事件”课程。由于日期的处理方式,我们需要将这个类包装在一个“UIEvent”类中,该类包含事件,以及另一种格式的事件日期。

允许从 Event 转换到 UIEvent 并返回的最佳方法是什么?我认为重载 UIEvent 的赋值或复制构造函数以接受事件(反之亦然)可能是最好的。

4

2 回答 2

21

我能想到两个简单的选择。

第一个选项将是您描述的选项:创建一个接受其他类型对象的构造函数:

struct UIEvent
{
    UIEvent(const Event&);
};

并用于std::copy将元素从一种类型的向量复制到另一种类型的向量:

std::vector<Event> eventVector;
std::vector<UIEvent> uiEventVector;

std::copy(eventVector.begin(), eventVector.end(), 
          std::back_inserter(uiEventVector));

第二种选择是编写一个非成员转换函数:

UIEvent EventToUIEvent(const Event&);

并使用std::transform

std::transform(eventVector.begin(), eventVector.end(), 
               std::back_inserter(uiEventVector), &EventToUIEvent);

这样做的好处是类之间的直接耦合较少。另一方面,有时类无论如何都是自然耦合的,在这种情况下,第一个选项可能同样有意义并且可能不那么麻烦。

于 2010-04-14T01:26:09.980 回答
5

如果您可以将 an 转换Event为 a UIEvent(例如,如果UIEvent有一个采用Eventas 参数的构造函数),那么以下会将一个向量分配给另一个向量:

uievent_vector.reserve(event_vector.size());
uievent_vector.assign(event_vector.begin(), event_vector.end());

如果该转换有效,那么反过来自然也可以。

或者,您可以使用std::copy()来获得相同的效果。如果您无法在类接口内以一种方式进行转换,请编写一个进行转换的函数,然后使用std::transform()

struct to_uievent {
    UIEvent operator()(const Event& e) {
        // ...
    }
};

// ...
    std::transform(event_vector.begin(), event_vector.end(),
                   back_inserter(uievent_vector),
                   to_uievent());

operator()()当然,您可以在上述函数对象中添加任意数量的重载,这样您就可以将相同的函数对象用于其他转换。

于 2010-04-14T02:43:38.670 回答