我有一个“事件”课程。由于日期的处理方式,我们需要将这个类包装在一个“UIEvent”类中,该类包含事件,以及另一种格式的事件日期。
允许从 Event 转换到 UIEvent 并返回的最佳方法是什么?我认为重载 UIEvent 的赋值或复制构造函数以接受事件(反之亦然)可能是最好的。
我有一个“事件”课程。由于日期的处理方式,我们需要将这个类包装在一个“UIEvent”类中,该类包含事件,以及另一种格式的事件日期。
允许从 Event 转换到 UIEvent 并返回的最佳方法是什么?我认为重载 UIEvent 的赋值或复制构造函数以接受事件(反之亦然)可能是最好的。
我能想到两个简单的选择。
第一个选项将是您描述的选项:创建一个接受其他类型对象的构造函数:
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);
这样做的好处是类之间的直接耦合较少。另一方面,有时类无论如何都是自然耦合的,在这种情况下,第一个选项可能同样有意义并且可能不那么麻烦。
如果您可以将 an 转换Event
为 a UIEvent
(例如,如果UIEvent
有一个采用Event
as 参数的构造函数),那么以下会将一个向量分配给另一个向量:
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()()
当然,您可以在上述函数对象中添加任意数量的重载,这样您就可以将相同的函数对象用于其他转换。