我使用地图< MyStruct,I *> MAP1 ;.显然,我的总应用程序时间的9%用于那里.具体在我的一个主要功能的一条线上.地图不是很大(< 1k几乎总是,< 20是常见的). 有没有可以使用的替代实现?我想我不应该写我自己,但如果我认为这是一个好主意,我可以. 附加信息:我总是在添加元素之前检查.如果存在密钥,我需要报告一个问题.比起一点,我将使用地图大量的查找,不会添加任何更多的元素.

解决方法

首先,您需要了解地图是什么,您正在做的操作代表什么. std :: map是一个平衡的二叉树,查找将采用O(log N)操作,每个操作都是密钥的比较加上大多数情况下可以忽略的一些额外的值(指针管理).插入大致相同的时间来定位插入点,加上新节点的分配,实际插入到树中并重新平衡.复杂度再次为O(log N),尽管隐藏常数较高.

当您尝试在插入之前确定地图中的一个密钥是否导致查找的费用,如果它不成功,则定位插入点的成本相同.您可以通过使用std :: map :: insert来返回一个与迭代器和一个布尔的对话框来告诉您插入是否实际发生或元素已经存在的额外成本.

除此之外,您需要了解比较键的成本是多少,这不是问题所在(MyStruct只能容纳一个或一千个),这是您需要考虑的因素.

最后,地图可能不是您需要的最有效的数据结构,您可能需要考虑使用预期定时插入的std :: unordered_map(哈希表)(如果哈希函数是不可怕),或者对于小型数据集,即使是可以使用二进制搜索来定位元素的简单有序数组(或std :: vector)(这将减少分配次数,代价是更昂贵的插入,但如果持有的类型足够小,可能值得)

一如往常的表现,衡量,然后尝试了解时间花在哪里.另请注意,根据您的应用程序,在特定功能或数据结构中花费的10%的时间可能很多或几乎没有.例如,如果您的应用程序只是执行查找和插入数据集,并且只需要10%的cpu,您就可以在其他地方进行优化.

c – stl地图演出?的更多相关文章

  1. 在编译时编译Xcode中的C类错误:stl vector

    我有一个C类,用gcc和可视化工作室中的寡妇在linux上编译.boid.h:并在boid.cpp中:但是,当我在Xcode中编译此代码时,我收到以下错误:有任何想法吗?我以为你可以使用C/C++代码并在Xcode中编译没有问题?.m文件被视为具有Objective-C扩展名的.c文件..mm文件被视为具有Objective-C扩展名的.cpp文件,那么它被称为Objective-C只需将.m文件重命名为.mm,右键单击或按住Ctrl键并在Xcode中的文件中选择重命名.

  2. android – 错误:’to_string’不是’std’的成员

    它可能是重复的,但我尝试了我在StackOverflow上找到的所有解决方案.我正在使用OpenCV在C上创建一个库,并尝试为Android编译它.我不能使用to_string(int)但我不能.我试图修改我的makefile太多次了.我的最后一个配置就是:Android.mkLOCAL_PATH:=$(callmy-dir)include$(CLEAR_VARS)OPENCV_CAMERA_MO

  3. 使用Android NDK和std :: vector修复Eclipse错误

    我正在使用eclipse开发一个也使用ndk的Android应用程序.我在我的应用程序中载入,我已经完成了必要的操作,让它们包含在内APP_STL:=stlport_static在我的Application.mk一切工作正常编译和运行,但是当我使用向量时,Eclipse会给我错误例如创建一个错误.如果我删除错误并继续进行编译并运行正常.我已经添加${NDKROOT}/sources/cxx-stl/gnu-libstdc/include在我的项目配置下,CGeneral–>路径和符号–>包括它解析#inc

  4. Android std和stl支持

    我正在玩androidndk.我正在使用WindowsVista与cygwin.我在手机上编译并推出了你好的世界jni样本.这是工作.代码是:我想添加一些修改,只是为了玩一下:然后,在上面的功能中,我补充说:但编译器却说找不到文件’algorithm’,而min()不是std的一部分.经过一番搜索,我发现androidndk有一个gnu-libstdc目录,其中包含所有std文件.阅读NDK文档,我已经了解到,usintstd::*应该没有任何修改代码.但似乎cygwin上的gcc无法找到所需的文件.为了

  5. ubuntu – My YouCompleteMe Vim插件不支持STL

    根据Github的介绍,我刚刚编译并安装了Vim,Vundle和YouCompleteMe插件.但是,在我的Vim中,YouCompleteMe插件不能正常工作.它可以自动完成变量的名称,但它不会自动完成STL对象的操作.甚至无法自动完成“this->”在课堂上它总是告诉我“找不到模式”.你有没有看过这个?我使用Ubuntu12.04.我该怎么办?

  6. STL中正则表达式的应用

    使用STL正则表达式首先需要包含正则库#include其中主要包括regex_search、regex_match、regex_replace三个函数regex_search:全字查找regex_match:部分查找regex_replace:正则部分替换重点看regex_match,部分查找,因为该功能对于较小的字符长度其实是能够包含regex_search的功能,并通过简单替换拼

  7. Ubuntu环境下编译V8

    Ubuntu版本:14.04关于V8V8是Google自己开发的高性能开源的JavaScript解析引擎。V8在Github上面的地址V8开发者页面下载源码源码地址根据文档中的介绍,首先看depottools是否安装。使用生成的默认的Makefile在Android平台上执行hello-world时会报错:参考这篇文章的解决办法,在out/Makefile.android_arm.release中加上删除out目录下面的android_arm.release目录:进入out/android_arm.rel

  8. c – 在现有数组周围的STL非复制包装?

    是否可以为现有的POD类型元素创建类似STL的容器,甚至是STL式迭代器?例如,假设我有一个int数组.可以方便地调用一些STL函数,如find_if,count_if或直接在该数组上排序.非解决方案:复制整个数组,甚至只是引用元素.目标是非常记忆和节省时间,同时希望允许使用其他STL算法.解决方法您可以直接在常规C风格的数组中调用许多STL算法–它们是为此设计的.例如.,:我想你会发现大多数的东西都像你所期望的那样工作.

  9. c – 多个代理类可以构成一个STL保护位向量吗?

    指针代理可以在大多数实现中包含与reference_proxy相同的数据,即指向打包数据的指针和用于隔离指向的块内的特定位的掩码.pointer_proxy的间接方法将产生reference_proxy.基本上两个代理都是“胖”指针,但是与基于磁盘的代理容器相比,它们仍然相当轻.而不是T*x=&v[0],则可以自动执行自动x=&v[0],并且像x一样使用x而没有问题.我也想写{/*…

  10. c – 对两个值对STL向量进行排序

    如何根据两种不同的比较标准对STL矢量进行排序?默认的sort()函数只需要一个单一的sorter对象.解决方法您需要将两个标准组合成一个.举个例子,你将如何排序一个第一个和第二个字段的结构体基于第一个字段,然后是第二个字段.注意:compare_entry的实现更新为使用Nawaz的代码.

随机推荐

  1. 从C到C#的zlib(如何将byte []转换为流并将流转换为byte [])

    我的任务是使用zlib解压缩数据包(已接收),然后使用算法从数据中生成图片好消息是我在C中有代码,但任务是在C#中完成C我正在尝试使用zlib.NET,但所有演示都有该代码进行解压缩(C#)我的问题:我不想在解压缩后保存文件,因为我必须使用C代码中显示的算法.如何将byte[]数组转换为类似于C#zlib代码中的流来解压缩数据然后如何将流转换回字节数组?

  2. 为什么C标准使用不确定的变量未定义?

    垃圾价值存储在哪里,为什么目的?解决方法由于效率原因,C选择不将变量初始化为某些自动值.为了初始化这些数据,必须添加指令.以下是一个例子:产生:虽然这段代码:产生:你可以看到,一个完整的额外的指令用来移动1到x.这对于嵌入式系统来说至关重要.

  3. 如何使用命名管道从c调用WCF方法?

    更新:通过协议here,我无法弄清楚未知的信封记录.我在网上找不到任何例子.原版的:我有以下WCF服务我输出添加5行,所以我知道服务器是否处理了请求与否.我有一个.NET客户端,我曾经测试这一切,一切正常工作预期.现在我想为这个做一个非托管的C客户端.我想出了如何得到管道的名称,并写信给它.我从here下载了协议我可以写信给管道,但我看不懂.每当我尝试读取它,我得到一个ERROR_broKEN_P

  4. “这”是否保证指向C中的对象的开始?

    我想使用fwrite将一个对象写入顺序文件.班级就像当我将一个对象写入文件时.我正在游荡,我可以使用fwrite(this,sizeof(int),2,fo)写入前两个整数.问题是:这是否保证指向对象数据的开始,即使对象的最开始可能存在虚拟表.所以上面的操作是安全的.解决方法这提供了对象的地址,这不一定是第一个成员的地址.唯一的例外是所谓的标准布局类型.从C11标准:(9.2/20)Apointe

  5. c – 编译单元之间共享的全局const对象

    当我声明并初始化一个const对象时.两个cpp文件包含此标头.和当我构建解决方案时,没有链接错误,你会得到什么如果g_Const是一个非const基本类型!PrintInUnit1()和PrintInUnit2()表明在两个编译单元中有两个独立的“g_Const”具有不同的地址,为什么?

  6. 什么是C名称查找在这里? (&amp;GCC对吗?)

    为什么在第三个变体找到func,但是在实例化的时候,原始变体中不合格查找找不到func?解决方法一般规则是,任何不在模板定义上下文中的内容只能通过ADL来获取.换句话说,正常的不合格查找仅在模板定义上下文中执行.因为在定义中间语句时没有声明func,并且func不在与ns::type相关联的命名空间中,所以代码形式不正确.

  7. c – 在输出参数中使用auto

    有没有办法在这种情况下使用auto关键字:当然,不可能知道什么类型的.因此,解决方案应该是以某种方式将它们合并为一个句子.这可用吗?解决方法看起来您希望默认初始化给定函数期望作为参数的类型的对象.您无法使用auto执行此操作,但您可以编写一个特征来提取函数所需的类型,然后使用它来声明您的变量:然后你就像这样使用它:当然,只要你重载函数,这一切都会失败.

  8. 在C中说“推动一切浮动”的确定性方式

    鉴于我更喜欢将程序中的数字保留为int或任何内容,那么使用这些数字的浮点数等效的任意算术最方便的方法是什么?说,我有我想写通过将转换放在解析的运算符树叶中,无需将表达式转化为混乱是否可以使用C风格的宏?应该用新的类和重载操作符完成吗?解决方法这是一个非常复杂的表达.更好地给它一个名字:现在当您使用整数参数调用它时,由于参数的类型为double,因此使用常规的算术转换将参数转换为double用C11lambda……

  9. objective-c – 如何获取未知大小的NSArray的第一个X元素?

    在objectiveC中,我有一个NSArray,我们称之为NSArray*largeArray,我想要获得一个新的NSArray*smallArray,只有第一个x对象…

  10. c – Setprecision是混乱

    我只是想问一下setprecision,因为我有点困惑.这里是代码:其中x=以下:方程的左边是x的值.1.105=1.10应为1.111.115=1.11应为1.121.125=1.12应为1.131.135=1.14是正确的1.145=1.15也正确但如果x是:2.115=2.12是正确的2.125=2.12应为2.13所以为什么在一定的价值是正确的,但有时是错误的?请启发我谢谢解决方法没有理由期望使用浮点系统可以正确地表示您的帖子中的任何常量.因此,一旦将它们存储在一个双变量中,那么你所拥有的确切的一

返回
顶部