草庐IT

MAP_SIZE

全部标签

c++ - vector.size() 的 GDB 错误值

一个简单的vector.push_back()导致我的代码出现一些错误:#includeusingnamespacestd;intmain(intargc,constchar*argv[]){vectorstack;stack.push_back(1);stack.push_back(1);//stack.size()becomes467369971afterthisstack.push_back(1);stack.push_back(1);...morepush_back()s...return0;}我正在使用GDB检查它的行为...奇怪的是stack.size()在第二个push_

c++ - Python -> C++ 习语 : Storing lambda expressions in a map/container

我正在学习C++(通过Qt4)利用我的python/pyqt4经验,但我似乎无法掌握将lambda表达式存储到容器中以用作回调的正确习惯用法。我有一个包含大量字段的结构。我想创建一个回调映射,可以以特定方式正确格式化字段。这是我想做的python等价物:fromPyQt4.QtCoreimportQVariant,QStringclassAType(object):def__init__(self):self.name="FOO"self.attr2="BAR"self.attr3="BAZ"#...callbacks={}callbacks['name']=lambdax:QVari

c++ - OpenGL:GL_TEXTURE_CUBE_MAP 和 GL_REFLECTION_MAP

我目前正在使用OpenGL开发一个项目。每次我尝试引用GL_TEXTURE_CUBE_MAP和GL_REFLECTION_MAP时,它们在我看来都是未定义的。我已经包含了gl.h、glu.h和glut.h,但它们仍然显示为未定义。有什么建议吗? 最佳答案 OpenGL-1.1之后的所有内容都不是Windows操作系统ABI(二进制接口(interface))规范和GLXOpenGL-1.2规范的一部分(Linux即将获得修订的OpenGLABI)任何超出该功能的内容都必须在运行时通过扩展加载机制加载,即使它是核心功能。使用GLEW最

使用 g++ 4.6 和 boost::unordered_map 的 C++11 相关编译错误

我有一段C++代码会因编译错误而失败,除非它在​​C++11模式下运行,但我无法弄清楚为什么会这样,因为代码没有(明确地)使用C++11特点:#include#include#includestructSomeStruct{boost::unordered_mapintMap;};intmain(intargc,constchar*argv[]){std::vectorvals;vals.resize(100);}在使用gcc4.6.3-1ubuntu5和boost1.48的Ubuntu12.0464位机器上编译时:g++test.cpp然后我得到这个编译错误:Infileinclud

c++ - 如何完全管理 std 容器(如 map)的堆内存分配?

我对使用多个stdmap很感兴趣,我希望它们都从一个公共(public)内存池中分配元素。根据我目前所读的内容,我可以使用自定义分配器(例如Boostpool_alloc)来实现这一点。我的问题是,尽管使用Boostpool_alloc之类的东西来管理元素本身的分配,stdmap是否仍会使用少量堆内存作为某种形式的容器开销,boostpool_alloc不会管理这些开销?我在考虑关于使用标准映射本身的指向元素的指针? 最佳答案 精简版map类型,例如:typedefstd::map,boost::pool_allocator>>AM

c++ - 将某些内容存储到 unordered_map 时出现浮点异常

我正在使用unordered_map作为C++中的HashMap,但每当我尝试在其中存储任何内容时,我都会得到:Floatingpointexception:8谁能指出错误是什么?以下是我如何初始化我的map(table_entry只是一个结构):std::tr1::unordered_mapforwarding_table;然后我在做一个条目:unsignedshortdest_id=0;table_entry*entry=(table_entry*)malloc(sizeof(table_entry));forwarding_table[dest_id]=entry;我的结构定义是

c++ - Visual Studio 2010 C++ : malloc()/HeapAlloc always allocates new page for even smallest alloc size

我有一个相当大的C/C++项目,我一直在试图找出它消耗过多内存的原因(通过任务管理器中的“工作集”判断)。我终于找到了奇怪的行为,即使是最小的malloc()请求,它也会分配一个全新的4k页面。像这样的代码for(intbla=0;bla这应该会增加区区10KB的内存消耗,最终会增加4MB,因为它分配了1000个4kB。真正令人沮丧的部分是我无法将其作为独立文件重现。仅包含上述代码的小型应用程序就可以正常工作。只有大项目才会表现出错误的行为。直接回答一些明显的建议:我正在引入与大项目相同的库,并确保编译标志相同"new"的行为方式相同在Debug和Release模式下都会发生我真的追踪

c++ - 将 QComboBox::currentIndexChanged(int) 连接到 QSignalMapper::map()

我想弄清楚如何在Qt5中实现这一点:connect(qcombobox,SIGNAL(currentIndexChanged(int),qsignalmappe,SLOT(map()));我试过这个:connect(comboBox,static_castsignalMapper,&QSignalMapper::map);但是编译器提示没有匹配的参数。我知道QSignalMapper::map()信号没有参数,但我不知道它如何使用旧语法。 最佳答案 试试这个,它对我有用connect(comboBox,static_cast(&QC

c++ - 使用 Eigen::Map<Eigen::MatrixXd> 作为 Eigen::MatrixXd 类型的函数参数

简而言之,问题是如何通过一个Eigen::Map反对一个期待一个函数Eigen::MatrixXd对象。长话短说:我有这个C++函数声明voidnpMatrix(constEigen::MatrixXd&data,Eigen::MatrixXd&result);连同这个实现voidnpMatrix(constEigen::MatrixXd&data,Eigen::MatrixXd&result){//Justdos.th.withargumentsstd::cout我想使用numpy.array作为参数从python调用这个函数。为此,我使用了一个用c++编写的包装器函数voidpyM

c++ - 通过 std::tuple<...> 实现 map() 和 each() - 将索引作为模板参数传递给仿函数

经过几年的Web开发,我再次使用C++(14)工作,并决定通过模板元编程获得一些“动态类型函数的乐趣”。我已经实现了map和each在元组上:templatevoidtuple_each_internal(Tupleconst&tuple,Funcfunc,index_sequence){autores={(func(get(tuple)),nullptr)...};}template::value>>voidtuple_each(Tupleconst&tuple,Funcfunc){tuple_each_internal(tuple,func,Indices());}structde