草庐IT

延时分配

全部标签

c++ - 如何让 tr1::array 分配对齐内存?

您可以分配一个std::vector,它通过定义您自己的分配器来分配对齐的堆内存。您可以使用declspecalign在堆栈上分配一个c风格的数组。但是你能声明一个tr1::array来保证索引为零的元素对齐吗? 最佳答案 tr1::array(以及std::array和boost::array)都是POD,所以内容占用的内存与数组的内存重合。因此,根据需要分配array,并使用new位置构造它。typedefstd::tr1::arrayAryT;void*array_storage=aligned_allocation(size

c++ - 许多堆栈分配与动态分配

在一个多维数组中,第二个维度的大小已知(尽管每个第一个维度不同),在性能方面是否更快地实际构建这些数组以进行硬编码:int*number[1000];intsecondDim[1];number[0]=secondDim;intsecondDimTwo[2];number[1]=secondDim;等等等1000次(我知道,我知道)或者动态分配每个第二维度:for(inti=0;i我只是想在这里围绕一个概念。 最佳答案 作为一般规则,您可以假设堆栈分配会更快。请记住堆栈的容量有限,过度使用大型堆栈分配数组可能会导致,等等......

c++ - 如何编译 Hinnant 的 short_alloc 分配器

我想试试新的Hinnant'sshort_allocallocator据我所知,它取代了旧的stack_alloc分配器。但是,我无法编译vector示例。g++说:~#g++-std=c++11stack-allocator-test.cpp-ostack-allocator-testInfileincludedfromstack-allocator-test.cpp:6:0:short_alloc.h:11:13:error:‘alignment’isnotatypeshort_alloc.h:11:22:error:ISOC++forbidsdeclarationof‘align

c++ - 是在索引一个新的 map 元素并将读取它的东西分配给它未定义的行为,还是只是未指定的?

回答后thisquestion,关于所讨论的代码是否为未定义行为的问题进行了长时间的讨论。这是代码:std::mapword_count;word_count["a"]=word_count.count("a")==0?1:2;首先,众所周知,这至少是未指定的。结果因首先评估作业的哪一侧而异。在我的回答中,我遵循了四个结果案例中的每一个,首先评估哪一方的因素以及该元素是否在此之前存在。还有一个简短的表格出现了:(x=0)=(x==0)?1:2;//startedas(x=0)=(y=="a")?1:2;//changedto我声称它更像这样:(x=0,x)=(x==0)?1:2;//c

Hive-使用REGXP创建组并将它们分配到数组中

我有一个正则表达式,可以在表中解析一些原始数据,例如:',?([\w]*|\d*)'.selectregexp_extract(raw_line,',?([\w]*|\d*){1}',1)asfield1,regexp_extract(raw_line,',?([\w]*|\d*){2}',1)asfield2,...,regexp_extract(raw_line,',?([\w]*|\d*){n}',1)asfieldnfromtable这将创建组以解析CSV字段。问题是桌子和分析的每行都很长,因此这是一个昂贵的操作。我想知道我是否可以使用正则表达式(没有组{n}并将其分成数组。然后,我可

静态单分配表格的优化

如果中间表示不在SSA(静态单个分配)中,则无法实现哪些优化技术?换句话说,SSA是可选的还是必需的?看答案特定优化不需要SSA,但通常使实施一些优化变得更容易。有些编译器不使用SSA(或至少在编译器的某些部分不使用它):例如,GCC低级IR称为RTL不是基于SSA的IR,GO的后端仅使用SSA,因为几个版本。Rust的新引入的MiR(中级IR)也不基于SSA。

C++ 在不重新分配的情况下删除 vector 末尾的一部分

查看C++vector文档,pop_back()是一个不会导致vector数据重新分配的函数。但是,这仅适用于删除vector的一个成员。我试图找到一种方法来从vector的末尾删除多个成员。最初我以为我会在一个小的for循环中调用pop_back()但我在徘徊是否有更方便的函数可以为我做这个?编辑:Cplusplusvectorerase()reference并不像juanchopanza指出的那样清楚。这就是为什么我最初放弃使用erase()的原因。毕竟删除,效果很好。 最佳答案 使用vector::erase。它不会重新分配内

c++ - 为什么 C++ 分配器避免就地重新分配

我对realloc的理解是,如果内存在分配点之外连续可用,它可以尝试扩展当前分配而不进行复制。阅读本文时https://github.com/facebook/folly/blob/master/folly/docs/FBVector.md我开始知道大多数分配器都避免就地重新分配.Manymemoryallocatorsdonotsupportin-placereallocation,althoughmostofthemcould.Thiscomesfromthenownotoriousdesignofrealloc()toopaquelyperformeitherin-placere

c++ - std::string 分配何时在初始化时发生

当我在类中创建一个std::string成员变量时,是否在实例化时已经分配了默认内存?还是std::string延迟分配直到它被实际使用?我目前正在使用VisualStudio2010,我注意到,当我创建一个空字符串时:std::strings0;std::strings1="";两者都有容量==15套。那么这是否意味着它已经分配了15个字节的内存?如果是,我可以阻止这种情况以便不分配内存吗?这会是跨不同编译器的特定实现吗? 最佳答案 标准未指定空std::string的初始容量,并且取决于实现。许多实现会分配大约16个字符的初始容

c++ - std::allocator_traits 默认为具有多个模板参数的分配器

std::allocator_traits当我提供一个带有单个模板参数的分配器的STL样式容器时,它会自动发挥它的魔力,但当我提供一个带有两个模板参数但其他方面相似的分配器的STL样式容器时,它不会自动发挥作用。我需要做什么来告诉std::allocator_traits如何与具有多个模板参数的分配器交互?是否有可能获得std::allocator_traits在这种情况下提供合理的默认值?例如,如果我采用HowardHinnant在AllocatorBoilerplate中提供的简单分配器并将其提供给std::vector那么一切都很好。如果我添加一个虚拟intallocator的参