草庐IT

template-parameter-lists

全部标签

c++ - 在类型说明符中使用 "simple-template-id"

在C++11标准中,dcl.type.simple和dcl.type.elab部分声明类型说明符可以包括simple-template-编号。另一方面,根据temp.names部分,simple-template-id可以表示函数模板特化。真的可以使用函数模板特化来指定类型吗? 最佳答案 7.1.6.2/2Theothersimple-type-specifiersspecifyeitherapreviously-declareduser-definedtypeoroneofthefundamentaltypes(3.9.1).强调

c++ - 为什么bitset要用template来实现?

要定义一个16位的位集,就像这样:std::bitsetbs(0x123);如果让我设计一个bitset类,我大概会这样:mine::bitsetbs(16,0x123);std::bitset是由模板实现的有什么原因吗?这是我们应该在某些情况下应用的好模式吗? 最佳答案 Isthereanyreasonthatstd::bitsetisimplementedbytemplate?Isthisagoodpatternthatweshouldapplyinsomesituations?因为std::bitset被设计成一个静态位集。在

c++ - 是数组 a<T, N> = { initializer-list };正确的语法?

在工作草案中http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2010/n3225.pdf23.3.2它说Anarrayisanaggregate(8.5.1)thatcanbeinitializedwiththesyntaxarraya={initializer-list};我会通过arraya={initializer-list};是正确的,有人可以解释一下这种奇怪的语法吗? 最佳答案 草稿有误。C++11标准的最终版本有arraya如您所料。

c++ - 错误 : Use of class template requires template argument list

当我尝试运行我的程序时,此错误显示为“errorC2955:'FOURTEEN':useofclasstemplaterequirestemplateargumentlist”#includeusingnamespacestd;templateclassFOURTEEN{private:Ta[n];public:voidReadData();voidDisplayData();};voidFOURTEEN::ReadData(){for(inti=0;i>a.[i];}voidFOURTEEN::DisplayData(){for(inti=0;i>a.[i]P;//Readdatai

c++ - 将 list<A*> 转换为 list<B*> ,其中 B 继承 A

我有一个函数voiddoSomething(listlist1,listlist2)和类classB:AclassC:A有没有直接调用函数的方式voiddoSomething(listlistOfB,listlistOfC)还是我必须像手动包装它一样voiddoSomething(listlistOfB,listlistOfC){listl1;listl2;for(B*b:listOfB)l1.insert(b);for(C*c:listOfC)l2.insert(c);doSomething(l1,l2);//callingthefunctiontakingsupertype}我尝试

c++ - initializer_list 作为数组引用参数的参数?

下面对foo的调用是否有效?GCC似乎对此很满意,而Clang为foo给出了“无匹配函数”错误;以及无法推断出N的注释。templatevoidfoo(constint(&x)[N]){}intmain(intargc,char*argv[]){foo({1,2,3});return0;} 最佳答案 编辑:随着CWGissue1591决议的通过在委员会2014年11月的session上,现在允许使用OP中的代码。编译器现在可以推断出数组中元素的类型和数量。§14.8.2.5[temp.deduct.type]/p5:Thenon-d

c++ - 我可以将 `extern template` 放入头文件中吗?

在头文件中放一个外部模板,然后在单元编译文件中显式模板实例化有效吗?例如在g++的编译示例中,这是为了避免nothing的实例化吗?两次?为什么没有人这样写而更喜欢复制externtemplate每个.cpp文件中的行?A.hpp:#ifndefHEADERC_A#defineHEADERC_Atemplatestructnothing{};externtemplatestructnothing;#endifA.cpp:#include"A.hpp"templatestructnothing;ma​​in.cpp:#include"A.hpp"#includeintmain(){not

c++ - std::list 的多元素插入是强异常安全的吗?

在exceptionalc++的第17项中,我发现:First,forallcontainers,multi-elementinserts("iteratorrange"inserts)areneverstronglyexception-safe.但在effectiveSTL的第1项中,我发现:Ifyouneedtransactionalsemanticsformultiple-elementinsertions(e.g.,therangeform—seeItem5),you'llwanttochooselist,becauselististheonlystandardcontaine

c++ - 可变参数模板 initilizer_list 技巧

我在visualstudio2017RC上使用C++17编写了for_each_tuple,我对这种实现感到震惊。查看:templateconstexprautofor_each_tuple(fun_t&fun,tuple_t&&tuple){std::apply([&](auto&&...args){autol={(fun(std::forward(args)),0)...};},std::forward(tuple));}intmain(){autotup=std::make_tuple(1,2,3,4);for_each_tuple([](auto&arg){++arg;},tu

c++ - 为什么 vector<double> 接受带有整数元素的 initializer_list?

#include#includeintmain(){//caseI:uniforminitialization//intii=100;//Error:cannotbenarrowedfromtype'int'to'double'//ininitializerlist//doubledd{ii};//caseII:initializer_list//std::vectorvecDouble{1,2.2};//fine!//caseIII:initializer_list//std::vectorvi={1,2.3};//error:doubletointnarrowing//caseIV