我有一个“活动”课程。由于处理日期的方式,我们需要将此类包装在“UIEvent”类中,该类保存事件,并以另一种格式包含事件的日期。
允许从Event转换为UIEvent并返回的最佳方法是什么?我认为重载UIEvent的赋值或复制构造函数来接受事件(反之亦然)可能是最好的。
答案 0 :(得分:14)
我能想到两个简单的选择。
第一个选项是你描述的选项:创建一个构造函数,它接受另一个类型的对象:
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);
这样做的好处是类之间的直接耦合较少。另一方面,有时类无论如何都是自然耦合的,在这种情况下,第一个选项可能同样有意义并且可能不那么麻烦。
答案 1 :(得分:5)
如果您可以将Event
转换为UIEvent
(例如,如果UIEvent
的构造函数以Event
作为参数),则以下内容将指定一个矢量到另一个:
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()()
重载,这样您就可以将相同的函数对象用于其他转换。