草庐IT

c++ - C++11 中的可变参数模板和多重继承

我正在努力实现这样的目标:我有一个模板化的基类,我想动态继承它templateclassfooBase{public:fooBase(){};~fooBase(){};};期望的方法:(像这样,不太确定该怎么做)templateclassfoo:publicInterfaces...{public:foo();~foo();}我的目标是让foo类像这样:第二种方法:classfoo():publicfooBase,publicfooBase,publicfooBase//andthelistcouldgoon{foo();~foo();}使用第二种方法的问题是,如果我实例化一个foo对

c++ - 非模板类方法的完美转发

完美转发通常出现在模板类的上下文中。对于非模板类,是否值得制作例如构造函数是一个模板方法,因此它可以使用完美转发?类似下面的内容:classFoo(){public:templateFoo(T&&vec):memberVec(std::forward(vec)){};private:std::vectormemberVec;};优点基本相同,但是当我们知道真正的类类型时,有什么不同吗?这什么时候是好的做法,什么时候不是? 最佳答案 非显式单参数构造函数是转换构造函数。除非Foo应该是可转换的vector(这可能是真的),你应该把它变

C++ 多参数模板化类成员特化

我正在设置一个c++(11)程序,我在其中使用了一个依赖于2个参数的模板化类。该类的大部分内容都可以根据模板参数进行通用编写。只有少数功能需要专门的版本。这是重现我的问题的示例模式:templateclassfoo{//typedefsandmembersthatdependonTandN//butthatcanbewrittengenericallye.g.:typedefstd::arraymyarray;voidmyfunc(myarraytab);};//...templatefoo::myfunc(myarraytab){//genericversion}//needspec

c++ - 将除最后一个以外的所有可变参数模板参数解压为变量类型

我有一个模板类,它接受可变数量的类型作为参数。构造函数接受指向使用Args...-1作为参数类型的类实例的指针。通过互联网搜索我发现std::tuple通常用于处理此类问题,但我不明白如何获取模板参数、创建元组、删除最后键入,然后再次解压元组并将结果存储在一个变量中,该变量稍后可以由parent()函数检索。templateclassMyClass{public:MyClass(MyClass*parent):parent_(parent)//ShouldbeArgs-1{}MyClass*parent(){returnparent_;}private:MyClass*parent_;

c++ - 存储可变参数模板的模板参数数量

在下面的例子中templatestructStaticArray{enum{N=sizeof...(Entries)};size_tarray[N]={Entries...};};在enum中存储条目数对我来说更像是一种hack。这真的是教科书上存储条目数的方法,还是有更简洁的方法? 最佳答案 我更喜欢staticconstexpr成员:templatestructStaticArray{staticconstexprsize_tN=sizeof...(Entries);size_tarray[N]={Entries...};};可

c++ - 我如何声明一个放在 main 之后的类模板?

我正在尝试实现一个堆栈模板类。但是我想在main之前声明它。我可以这样做吗?我知道如果将main放在模板之后它会编译,但是是否可以先将main然后是模板?#include//startdeclarationoftemplatetemplateclassstack;//enddeclarationoftemplateintmain(){stacks(5);s.push('a');s.push('b');couts1(10);s1.push(3.2);s1.push(0.5);coutclassstack{T*s;intsize;//HowmanyelementsIcanstole.int

c++ - 在 std::unordered_map 中使用模板化键

我不明白为什么我的编译器不接受下面的代码#include#includetemplateusingM=std::unordered_set;templateusingD=M;templateusingDM=std::unordered_map::const_iterator//Problem,typenameD::const_iterator>;//Problemintmain(intargc,char**argv){Dd;Mm;DMdm;//Problem}编译命令是clang++-std=c++14test.cpp-otest编译器错误消息摘录是/usr/bin/../lib/gc

c++ - Lambda 作为模板函数

我有一个很奇怪的问题。为了简单起见,假设我想要一个函数,它接受两个函数,它们的声明与参数相同templatevoidfoo(Funca,Funcb){std::cout为了尝试一些事情,我从cstdio中获取了putchar,并创建了一个相同的函数来匹配putchar。intmyPutcharFunc(int){return0;}intmain(){automyPutcharLambda=[](int)->int{return0;};foo(putchar,myPutcharFunc);//okayfoo(putchar,myPutcharLambda);//deducedconfli

c++ - 嵌套模板 : "expected primary-expression before ' )'"

我正在用C++编写一个Point类并为此使用模板。但是我有一个我不明白的编译错误。我写了一个问题的最小示例:#include#include#includetemplateclassPoint{private:std::arrayvalues;public:templateTget(){returnvalues.at(ROW);};};templateclassField{public:Tprint(std::vector>&vec){for(autoit:vec){Tbla=it.get();//theerrorline27}};};intmain(intargc,char*argv

c++ - 模板类型推导

我遇到过class=std::enbale_if::type在模板参数列表中几次,我知道什么std::enable_if::type确实但不确定是什么class=做?我是说我知道classtype_name=type但为什么class=中没有类型名称?我什么时候使用它?编辑:这个例子来自heretemplate::value?is_lvalue_reference::value:true>::type>inlineT&&forward(U&&u){returnstatic_cast(u);} 最佳答案 这是SFINAE(替换失败不是