草庐IT

allocator_traits

全部标签

c++ - 如何在类范围内定义/专门化 type_trait?

我有以下情况:我的问题围绕使用强类型枚举类作为标志(就像在C#中使用Flags-Attribute一样)。我知道这不是首先要使用枚举类的方式,但这不是这个问题的重点。我已经定义了几个用于这些枚举类的运算符和函数,以及一个自定义类型特征来区分普通枚举和标志枚举。这是一个例子://Defaulttype_traitwhichdisablesthefollowingoperatorstemplatestructis_flags:std::false_type{};//Exampleoperatortouseenumclassasflagstemplatestd::enable_if_t::v

c++ - C++中 "allocation unit"的定义?

C++17标准在12.2.4节中讨论位字段时多次使用术语“分配单元”,但似乎并未定义该术语的含义。该标准还指出,“作为一种特殊情况,宽度为零的未命名位域指定分配单元边界处下一个位域的对齐方式。”所以我有两个关于这些概念的问题,以下面的代码为例:术语“分配单元”在标准中是什么意思?为未命名的位字段指定的数据类型有什么意义?在第二个问题中,我的假设是数据类型意味着后面的位域应该在该数据类型的下一个边界上对齐。structtag{charX:3;unsignedint:0;//startnextbit-fieldonnextunsignedintboundary?charY:4;unsign

c++ - allocator.construct 循环是否等于 std::uninitialized_copy?

在此背景下T是某种类型并且allocator是该类型的分配器对象。默认情况下为std::allocator但这不一定是真的。我有一大块内存被allocator.allocate(n)获取了.我还有一个容器con的T对象(比如std::vector)。我想用T初始化那block内存对象。内存块的位置存储在T*data中。.这两个代码示例是否始终相同?#include//example1std::uninitialized_copy(con.begin(),con.end(),data)//example2std::vector::const_iteratorin=con.begin();

c++ - 如果自定义分配器中不存在重新绑定(bind),std::allocator_traits 是否定义 rebind_alloc?

我正在尝试重新绑定(bind)我的自定义分配器类型,MyAllocator,用于basic_string类,例如:std::basic_string,MyAllocator>...分配器作为MyAllocator传递给上下文,所以我需要重新绑定(bind)分配器。来自std::allocator_traits的cppreference页面,http://en.cppreference.com/w/cpp/memory/allocator_traits:Memberaliastemplates:rebind_alloc:Alloc::rebind::otherifpresent,othe

c++ - 如何追踪 "tcmalloc : large alloc .... "

我的应用打印几行,如:tcmalloc:largealloc4294488064bytes==0x2b968d8000@0x7274320x7273020x727a580x75a07d0x574beb0x5857560x5575df0x5717db0x57108f0x58078c0x302b80610atcmalloc:largealloc4294488064bytes==0x2c97063000@0x7274320x7273020x727a580x75a07d0x574beb0x5857560x5575df0x5717db0x57108f0x58078c0x302b80610atcm

c++ - std::allocator 中的直接初始化与统一初始化

ThisquestionhasalsobeensubmittedtoUsenet,whereitismoreappropriate,butthisisalargerandmorereliableforum.std::allocator::construct被定义为转发其参数参数使用括号打包到对象构造,也就是直接初始化。如果它使用大括号,也就是统一初始化,我们可以初始化从诸如std::make_shared和容器::放置。另外,把内容放上去也是可以接受的将初始化列表放入此类函数的参数列表中,解决initializer_list下的类型推导问题转发。这个备选方案是否被考虑过并被拒绝了?现在

c++ - 使用 std::allocator_traits<A>

我想设计一个类模板,它采用分配器类型(如标准第17.6.3.5节中所定义)作为模板参数。我怎么看std::allocator_traits有助于填补A的任何缺失成员使用默认设置。除此之外,标准库或boost中是否有任何有助于正确使用分配器的内容?特别是:尊重类型定义,如std::allocator_traits::propagate_on_container_copy_assignment,我是否必须在每个类的特殊成员函数中检查这些东西,每个类都有一个A类型的成员??或者是否有一些包装器类型我可以用作成员来代替它来处理这些东西?如果我想通过在用户可见对象旁边存储额外数据来过度分配以减少

c++ - XCode 4.5 'tr1/type_traits' 找不到文件

我使用wxwidget库,但遇到以下问题:#ifdefined(HAVE_TYPE_TRAITS)#include#elifdefined(HAVE_TR1_TYPE_TRAITS)#ifdef__VISUALC__#include#else#include#endif#endif这里找不到#include。我使用AppleLLVM编译器4.1。(使用c++11方言)。如果我切换到LLVMGCC4.2编译器,我在那里没有错误,但主要问题是所有c++11包含都不起作用。我怎样才能使用GCC编译器,但使用c++11标准或使LLVM可以找到?如有任何帮助,我们将不胜感激。

c++ - 如何使用 type_traits 生成依赖于类特化是否存在的代码?

背景我正在尝试写一个classtemplateHasher这将以两种不同的方式实现,具体取决于是否std::hash已为T实现:templatestructHasher{std::size_thash(Tt)const;//implementasA{std::hashh;returnh(t);}//orB{std::hashh;returnh(t.to_string());}};如果std::hash已经专精了,想用。如果没有,我希望T有一个to_string()函数返回一个key供我哈希。例如,根据cppreference,如果T是longlong、指针或std::string,我想

c++ - 如何使用 std::scoped_allocator_adapter?

据我了解,std::scoped_allocator_adapter提供一种控制机制,用于指定单独哪个分配器将由容器、其元素、其元素的元素等使用,假设元素本身是容器。也就是说,我无法理解std::scoped_allocator_adapter的语义.BjarneStroustrup在TheC++ProgrammingLanguage,section34.4.4,pg中提供了以下4个示例。1001(在接下来的问题中,我将它们称为Example-1、Example-2等。):Wehavefouralternativesforallocationofvectorsofstrings://v