- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我创建了这个模板函数来查找和删除 shared_ptr 集合中的项目
template<class T>
bool FindAndDelete(set<shared_ptr<T>>& collection, shared_ptr<T> item)
{
auto foundItem = find(collection.begin(), collection.end(), item);
if(foundItem != collection.end())
{
collection.erase(foundItem);
return true;
}
else
{
return false;
}
}
问题:我怎样才能更多地概括它以涵盖所有集合? ( vector 、列表等...)
例如
template<class K, class T>
bool FindAndDelete(K<shared_ptr<T>>& collection, shared_ptr<T> item);
注意:我来自 C#,所以代码可能有点偏差 :) 请纠正我
最佳答案
如果你想从容器中移除元素,那么像这样的东西会起作用:
template<class K>
bool FindAndDelete(K& collection, typename K::value_type item);
请记住 value_type
的 map 是 std::pair<key_type, mapped_type>
,因此您可能希望为它们提供特殊版本,例如
template<typename T, typename K>
bool FindAndDelete(std::map<T,K>K& collection,
typename std::map::<T,K>::key_type key);
对于 std::multimap
同样如此和 C++11 std::unordered_*
变体。这些容器有 find
比 std::find
更高效的成员函数, 因此值得专门实现 findAndDelete
利用这一点。
你也可以看看 std::remove_if和 erase remove idiom作为非关联容器实现的替代方案。如果您有重复项,这可能会更有效。
关于c++ - 将在 STL 集上运行的函数泛化到所有集合,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13561466/
我想概括 ($)喜欢 Control.Category概括(.) ,并且我已经使用本文末尾的代码 (also ideone) 完成了此操作。 在这段代码中,我创建了一个名为 FunctionObjec
我写这个问题是因为我只找到了有关我的场景的部分信息。 在 Azure 中克隆 VM,在我可以创建尽可能多的副本之后,我需要取消分配和泛化。我没有找到的详细信息是: VM 在核心方面概括了我的“成本”?
我写这个问题是因为我只找到了有关我的场景的部分信息。 在 Azure 中克隆 VM,在我可以创建尽可能多的副本之后,我需要取消分配和泛化。我没有找到的详细信息是: VM 在核心方面概括了我的“成本”?
我正在做一个关于使用邻接列表实现图的教程任务,但构造函数出现问题。 在给定的GraphTester.java中我有: //Constructor cannot be applied to given
我有一个疑问。想象一下,我有三个类别:学生、 worker 、学生/ worker 。 正确的是: ProfissonalArea | |
能否对这段代码进行泛化,以便我可以拥有可变数量的类型/参数? (我真的更喜欢将函数保留在结构之外,以保持代码更干净。) unsigned int const maxID = 2 ^ 8; typede
我想寻求您的帮助以解决我正在尝试解决的涉及 XPath 的问题。 我正在尝试概括用户提供的多个 Xpath,以获得最适合所有提供的示例的 XPath。这是我正在构建的网络抓取系统。 例如:如果用户提供
因此,有一种称为“折叠的通用属性”的东西,确切地说如下: g [] = i; g (x:xs) = f x (g xs) g = fold f i 但是,正如您现在可能的那样,有像 dropWhil
所以我有两种方法: private void updateJobType(, Boolean addTarget, JobType target) { if (addTarget == Boolea
是否有用于搜索图中结构的 levenshtein 距离的概括? 最佳答案 这篇论文可能会引起您的兴趣:Structural Similarity in Graphs 然而,我担心计算这样的距离会非常计
这个问题在这里已经有了答案: How to align checkboxes and their labels consistently cross-browsers (40 个答案) 关闭 9
我一直坚信,如果您复制和粘贴代码,那么会有更优雅的解决方案。我目前正在用 C++ 实现一个字符串后缀特里树,并且有两个实际上相同的函数,只是它们的返回语句不同。 第一个函数检查子字符串是否存在,第二个
我在 MVC 模式中的模型设计方面遇到了问题,并且我坚持使用 C# 的静态类型。 我想做的只是制作一组执行所有数据库插入、更新、删除操作的类。该组由从数据库中的每个表映射的类子组和访问表类的表模型类子
我在一个非常静态的环境中编程,希望以尽可能最好的方式概括问题/代码,使其干净并避免任何样板代码。这是我的情况;我正在开发一个位于程序 和扩展 之间的修改系统,其中扩展将转发 API 调用。当我的修改被
我有一个 api,它为我提供了如下方法: 按用户名搜索用户(用户名,限制) getRandomPremiumUsers(限制) getYoungUsers(maxAge, 限制) 我正在实现一个钩子(
除了通常的 ** 之外,大多数 UNIX 正则表达式都有, + , ?*运算符反斜杠运算符,其中 \1,\2,...匹配最后一个括号中的内容,例如 *L=(a*)b\1*匹配(非常规)语言 *a^n
我正在尝试使用复选框概括选择查询,您将看到的变量选择是从前端文件发布的,该文件使用复选框在后端创建数组。然后,该数组用于 select 语句的 SELECT 子句。目前,表头输出正确的 header
我需要构建一个乘积运算符,将两个任意大小的 vector 的乘积作为矩阵返回。 例如产品 u = [u1; u2; u3] 和 v = [v1; v2; v3] 将是u*v' = [u1*v1 u1*
目前,我有一个功能代码可以在我的页面上动态添加和删除表单输入。我有多个表单需要包含在页面上,所以我做了一个事件操作,他们可以按下一个按钮,它会隐藏除相关表单之外的所有表单。这工作正常,但它与我的 jQ
我正在使用 ExoPlayer 2 播放来自网络的音乐。现在我想通过使用漂亮的 SimpleCache 类来缓存下载的音乐。我的问题如下:每次我请求播放歌曲时,服务器都会返回一个不同的 URL(也是针
我是一名优秀的程序员,十分优秀!