我正在阅读有关在 C++ 中构建自定义异构容器的博客。在博客中,作者使用访问者模式打印出容器中按类型排序的每个元素。我想知道我是否可以写一个访问者,以便我可以按照插入的顺序打印出元素?
问问题
51 次
1 回答
1
当您按类型存储元素时,您会丢失插入顺序,因此您必须更改
template<class T>
static std::unordered_map<const heterogeneous_container*, std::vector<T>> items;
经过
template <class T>
static std::unordered_map<const heterogeneous_container*,
std::vector<std::pair<std::size_t, T>>> items;
添加一个visit_ordered:
template <typename T, class V>
void visit_with_index_impl_help(V& visitor)
{
for (auto&& p : items<T>[this])
{
visitor(p.first, p.second);
}
}
template <class V, typename... Ts>
void visit_ordered_impl(V& visitor, type_list<Ts...>)
{
std::vector<std::pair<std::size_t, std::function<void()>> funcs;
const auto inserter = [&](std::size_t i, auto&& elem) {
funcs.emplace_back(i, visitor(elem));
};
(..., visit_with_index_impl_help<Ts>(inserter));
const auto less_by_first = [](const auto& lhs, const auto& rhs){ return lhs.first < rhs.first; };
std::sort(funcs.begin(), funcs.end(), less_by_first);
for (auto&& func : funcs) {
func();
}
}
template <class V>
void visit_ordered(V& visitor)
{
visit_ordered_impl(visitor, typename std::decay_t<V>::types{})
}
于 2020-12-05T08:24:06.220 回答