草庐IT

信道分配

全部标签

c++ - size_t 和内存分配

有这样一个类型std::size_t。它可用于描述对象的大小,因为它保证能够表达任何对象的最大大小(所以写成here)。但是,这是什么意思?我们实际上在内存中没有对象。那么这是否意味着这种类型可以存储一个整数,代表我们理论上可以使用的最大内存量?如果我尝试写类似的东西size_tmaxSize=std::numeric_limits::max();newchar[maxSize];我会得到一个错误,因为数组的总大小被限制为0x7fffffff。为什么?此外,如果我传递一个等于maxSize的非常量表达式,将抛出std::bad_array_new_length。如果我传递一个小于max

c++ - 哪个是 G++ 4.4.1 默认分配器?

我想知道在Ubuntu9.1上G++4.4.1中哪个是默认内存分配器。我有兴趣在多线程环境中比较不同的C++分配器。我在哪里可以获得有关默认内存分配器的更多信息?编辑:我指的是新建和删除运算符。唯一的链接是rt和pthread问候 最佳答案 您可以使用LD_PRELOAD变量来使用您自己的分配器。LD_PRELOAD="/path/your_lib_exporting_malloc.so"在同一终端中运行与glibc动态链接的任何应用程序实际上将使用您提供的malloc实现。许多malloc实现都是免费的。*TLSF*jemallo

c++ - 需要 Boost Pool 经验。作为预分配的分配器有用吗?

最近我一直在寻找一个池/分配器机制。BoostPool似乎提供了解决方案,但仍有一些东西无法从文档中推断出来。需要分配什么几个小类(~30个字符)std::map(我想确保它不会自己执行动态分配器)在pugi::xml中分配标准::字符串如何控制分配的地址空间(或数量)object_pool似乎提供了一种分配需求的好方法1)但是,它想为分配器设置一个固定大小以供使用。默认情况下,它会自己获取内存。如果可能的话,我想给它一个它可以在其中播放的地址空间。char*mem_for_class[1024*1024];boost::object_poolq;或:constintmax_no_ob

c++ - 是否有 BOOST 池固定大小的分配器?

我要创建unordered_map(因为我特别想要一个HashMap)。我想在开始时分配它的最大大小(根据我的限制)。因此,如果我要分配256个条目,并且每个条目的大小为1B(只是一个例子。假设1Byte包括Key和Value)。那么我的总大小unordered_map键+条目是256B。我想在分配器中预分配256B。然后,当unordered_map会调用allocate()/deallocate(),allocator将从已经分配的内存中给它1B。typedefboost::unordered::unordered_map,std::equal_to,???>>myMap它存在于B

c++ - 确认此标准库错误与 MSVC 2015 RC 中的分配器有关

这是一个SSCCE:#include#includetemplatestructmy_allocator:std::allocator{//Thisoverridingstructcausestheerrortemplatestructrebind{typedefmy_allocatorother;};//Ignoreallthis.typedefstd::allocatorbase;typenamebase::pointerallocate(typenamebase::size_typen,std::allocator::const_pointer/*hint*/=nullptr){

c++ - 在编译时捕获 std::function 分配

我只想允许在我的代码库中使用std::function,前提是它不进行任何分配。为此,我可以编写类似下面的函数,并且只用它来创建我的函数实例:templatestd::functionmakeFunction(Functorf){returnstd::function(std::allocator_arg,DummyAllocator(),f);}如果DummyAllocator在运行时被使用,它将在何处断言或抛出。理想情况下,我想在编译时捕获分配用例。即templatestd::functionmakeFunction(Functorf){static_assert(sizeneed

c++ - C++03 标准容器的堆栈分配器

对于一个软件,我必须避免在堆中使用任何内存,并且只依赖堆栈分配的内存。然后,这使我无法使用我真正想使用的任何C++标准容器,例如vector、映射、字符串(好吧,basic_string)来简化开发和数据操作。我发现了(许多)堆栈分配器的实现,例如thisone它本身引用了另外两个,或者thisone来自Chrome。其中许多并不完全符合标准,或者依赖于C++11(遗憾的是,我目前还在使用C++03)。您对C++03现有的良好堆栈分配器有任何反馈,或者我应该采用上述之一吗?谢谢! 最佳答案 HowardHinnant的short_a

c++ - 跟踪(堆栈分配的)对象

在一个相当大的应用程序中,我想跟踪有关某个类对象的一些统计信息。为了不降低性能,我希望在拉取配置中更新统计信息。因此,我需要在某个位置引用每个事件对象。是否有一种惯用的方法可以:创建、搜索、迭代此类引用自动管理它(即在销毁时删除引用)我在这里考虑一组智能指针,但内存管理会有些颠倒:当智能指针被销毁时,我不想销毁对象,而是希望智能指针被删除,当对象被销毁。理想情况下,我不想重新发明轮子。我可以忍受删除指针的延迟,我只需要一种快速使它们失效的方法。编辑:因为paddy自找的:pull-based收集的原因是获取信息的成本可能相对较高。推送显然是一种干净的解决方案,但被认为过于昂贵。

c++ - std::vector insert() 重新分配

我查看了std::vector代码,发现了一些我不太明白的东西。当capacity分配新缓冲区复制旧缓冲区的前缀(0-插入索引)在新缓冲区中构造新元素复制旧缓冲区的后缀(index-end)对旧缓冲区中的所有项目调用析构函数释放旧缓冲区据我所知,前缀和后缀的复制是用memmove完成的。memmove不是数据的纯二进制拷贝吗?它不会调用元素的构造函数,是吗?我想知道的是,如果内存只是移动,而不是在新缓冲区中重新构造,为什么函数会调用旧缓冲区中元素的析构函数? 最佳答案 我查看了MSVC8vector实现-我看不到memmove().

c++ - 具有固定插入次数的 Map 的内存分配

我想将n个元素插入到一个映射中,其中n是提前已知的。我不想在每次插入时分配内存。我想要一开始就分配所有内存。有没有办法做到这一点?如果是这样,如何?编写某种内存分配器会有帮助吗?我运行了GMan的代码并得到了以下输出。GetMem从对“new”的调用中打印出来,而FreeMem从对delete的调用中打印出来。size是请求的字节数,ptr是返回的指针。显然,分配/释放是在插入期间进行的。你怎么解释这个?GetMem大小40,指针0x8420008GetMem大小40,指针0x8420038GetMem大小120,指针0x8420068GetMem大小120,指针0x84200e8Fr