草庐IT

STL_container_type

全部标签

c++ - 为什么 std::allocator<>::deallocate() 有一个未使用的 size_type 参数?

使用std::allocator时,deallocate函数需要pointer参数,和一个size_type参数(std::allocator::deallocate(std::allocator::pointerp,std::allocator::size_type)。但是,没有使用size_type,也不是可选的。那么为什么它在那里?这让我很困惑,因为它应该是可选的,甚至不在那里,因为它没有在函数中使用.编辑:MSVC的分配器实现deallocatevoiddeallocate(pointer_Ptr,size_type){//deallocateobjectat_Ptr,igno

C++1y/C++14 : Converting static constexpr array to non-type template parameter pack?

假设我有一个静态存储持续时间的constexpr数组(已知范围):constexprTinput[]=/*...*/;我有一个需要打包的输出类模板:templatestructoutput_template;我想像这样实例化output_template:usingoutput=output_template;一种方法是:templatestructmake_output_template{templatestaticconstexproutput_templatef(std::index_sequence){return{};};usingtype=decltype(f(std::m

c++ - 错误 : invalid operands of types 'int' and '<unresolved overloaded function type>' to binary 'operator<<'

我想获取z_Data的第48个字符的第6位{charc=pPkt->z_Data[47];//thisz_Dataisacharbufferstd::cout>3)&1>4)&1>5)&1 最佳答案 优先级高于&,所以你需要:std::cout>3)&1)>4)&1)>5)&1) 关于c++-错误:invalidoperandsoftypes'int'and''tobinary'operator https://stackoverflow.com/questions/246

c++ - 一个通用的 STLish contains()

令我恼火的是,STL容器没有contains()方法返回true如果容器包含元素false否则。所以,我坐下来写了这个:templateinlineboolcontains(constC&container,constE&element){returncontainer.find(element)!=container.end();}对于集合和映射来说效果很好,但对于vector就不行了。或列表。我该如何进行?我应该再写一个吗templateinlineboolcontains(constvector&container,constT&element){std::find(vector

c++ - QMetaType::Float 不在 QVariant::Type 中

我有一个运行良好的应用程序,但它不是在打开警告的情况下编译的。我正在尝试将其重新打开并整理它们,但没有关于如何解决此问题的想法。我有:QVariantsomeVarQVariant::TypevariantType=someVar.type();switch(variantType){caseQMetaType::QString:doSomething1();break;caseQMetaType::Float:doSomething2();break;}并收到此警告/错误:error:casevalue‘135’notinenumeratedtype‘QVariant::Type’[

C++ : union of two types without virtual base class inheritance

是否可以在不手动创建交集类型的情况下创建两种类型的并集?问题是在我的上下文中交集类是完全没有意义的,所以创建它会使代码用户感到困惑。我的实际案例:我正在描述一个数字硬件模拟器,它是许多模块的分层树状结构:classport;classmodule0{porta,b,c;}classmodule1{portc,d,e;}我需要创建这两种类型的union:classtop_level_module{porta,b,c,d,e;}我想应该有一些技术来创建union类型(这是我要问的问题):classtop_level_module:union_type{//porta,b,c,d,e;}但是

c++ - STL算法和back_inserter可以预分配空间吗?

如果我有类似的东西:vectorlongVector={...};vectornewVector;transform(longVector.begin(),longVector.end(),back_inserter(newVector),[](inti){returni*i;});STL是否能够在处理和添加新元素之前在newVector中预分配空间?我知道这不是算法的要求,但是“好的”实现能够优化它吗?或者,对于这种情况,我应该更喜欢在之前添加newVector.reserve(longVector.size());吗?我不一定要问每个stdlib实现是否有(尽管如果有人知Prop体

c++ - 是否允许在 requires 表达式中为 return-type-requirement 指定类型?

看看这个简单的概念示例:templaterequiresrequires(Tt){{t+t}->bool;}voidfn(){}intmain(){fn();}这里,我使用bool作为return-type-requirement的type-constraint。当前稿says:type-constraint:nested-name-specifieroptconcept-namenested-name-specifieroptconcept-name所以type-constraint必须是一个concept-name。bool(或任何类型)是否允许作为概念名称?如果是,那是什么意思,

算法中的C++入门及STL

目录1.C++入门1.1.常用头文件1.2.C++命名空间1.3.输入输出1.3.1.输入std::cin(cin) 1.3.2.输出std::cout(cout) 1.3.3.换行std::endl(endl) 1.4.C++结构体1.4.1.结构体声明1.4.2.结构体重载1.4.3.结构体函数1.4.3.1构造函数1.4.3.1.1.参数全初始化1.4.3.1.2.参数部分初始化1.4.3.1.3.简便写法1.4.3.2.结构体中的其他函数2.STL2.1.容器2.2.迭代器2.3.vector2.3.1.功能2.3.2.vector和普通数组的区别:2.3.3.动态扩展2.3.4.ve

c++ - RAII 和 C++ STL

我有一个案例,我希望将资源列表存储在std::vector中。在我看来,我的选择如下:给我的资源一个默认构造函数将它们存储为堆对象(并将它们包装在共享指针中)选项1使构造无效资源成为可能,选项2强制我使用堆。我是否遗漏了任何选项? 最佳答案 您不需要默认构造函数来拥有实例vector。唯一的限制是当类没有默认构造函数时,您不能将vector::resize与默认参数一起使用。vec.resize(20);//requiresdefaultconstructor但是你可以给vector::resize一个默认对象:std::vecto