创建可变参数模板类的forward_list
Making a forward_list of a variadic template class
我有一个std::forward_list
和一个我有一个类Delegate
(取自这里),它是一个具有可变参数类型签名(typename return_type, typename... Args
)的类。
我想从这些Delegate
中做出std::forward_list
。我将如何去做?我试过:
std::forward_list<Delegate<void, typename...> >
但它给出了语法错误。我稍后还想添加到此列表中。我可以保证这些列表中的每一个(将有多个)将只有Delegate
类型,这些类型采用相同数量的参数存储在一起。但是,每个列表可能都有一个方法列表,这些方法采用与其他列表中的方法不同的参数。
这些列表实际上将在std::unordered_map
内。
首先,听起来你应该使用unordered_multimap
而不是以列表作为值的地图。
也就是说,如果您尝试将类型存储在 STL 容器中,这些类型甚至略有不同,则需要创建一个基类并将它们存储为指向该基类的指针。 您提到一个列表中的所有值将具有相同数量的参数,但您没有指定参数将完全相同。
相关文章:
- 使用std::multimap迭代器创建std::list
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- 如何在 C 中正确使用 libiconv 使其不会报告"Arg list too long"?
- C++中带有List类的迭代器Segfault
- 使用"std::unordereded_map"映射到"std::list"对象
- GCC对可能有效的代码抛出init list生存期警告
- 使用std::list创建循环链表
- 重载Singly Linked List中的赋值运算符
- 完美前进使用 std::forward vs RefRefCast
- '[](std::list& list)<int>{return std::move(list)}(list)' 是否保证将 'list' 留空?
- 如果 KEY 是 std::list 或 std::vector 而不是值,那么 std::map 的默认行为是什么?
- 为什么这个 std::queue/指向结构的指针列表直到 List.Size() == 0 才释放内存?
- "std::list::splice(std::const_iterator pos, std::list&& other)"是否保证将"其他"留空?
- 从嵌套循环中的 std::list 中删除将返回访问冲突
- QStringList vs list<shared_ptr<QString>> 性能比较C++
- 包含 std::list 的结构体的 C++ 初始化
- 在C++中使用 Catch 测试框架编译错误"error: expected ';' at end of declaration list"
- C++ assigment std::list:<typename>:itrator 在 main 中工作,但在方法中它不起作用
- 在基于范围的 for 循环期间插入 std::list 的后面
- 循环挂起迭代的 std::擦除 on std::list