草庐IT

Templates

全部标签

c++ - 使用模板特化、默认参数和 VS2013 编译错误

templatevoidf(constT&v=T());templatevoidf(conststd::string&v){std::cout();//ErrorinVS2013,OKinVS2012,gcc-4.7f("Test");//OKf(std::string());//OKreturn0;}对于必须使用默认参数的情况,最新的VisualStudio2013编译器会给出以下编译器错误:errorC2440:'defaultargument':cannotconvertfrom'conststd::string*'to'conststd::string&'Reason:cann

c++ - 在模板参数的方法中添加类型转换时出现 clang 错误

我有一个模板结构,它将方法的类型和指向方法的指针作为参数,并将其包装在类似C的函数中:templatestructproxy;templatestructproxy{staticRcall(T&obj,Args&&...args){return(obj.*mf)(std::forward(args)...);}};proxy结构在简单的场景中按预期工作,例如:structFoo{intfoo(intx){returnx+1;}};...Foof;proxy::call(f,10);问题是当我在可能展开到的宏中使用代理时:proxy::call(f,10);在clang中,错误是:err

c++:通过多级继承从模板子类调用基类的模板方法

我正在寻找从通过C::A和B::A继承它的子类D调用基类A的方法。templateclassA{public:templatevoidFunc(void){std::cout::Func"classB:publicA{};templateclassC:publicA{};classD:publicB,publicC{public:D(){static_cast*>(this)->A::Func();static_cast*>(this)->A::Func();}};这按预期工作,D在初始化时使用子类的模板参数调用B::A::Func和C::A::Func。但是,当D是模板类时,这似乎不

C++: boost::fusion::for_each 对于许多序列

目前,boost::fusion::for_each迭代单个序列的元素。我正在尝试创建一个函数,该函数将以类似的方式工作,但具有许多序列,并将遍历序列之间的所有可能组合。例如,如果我有三个序列S1、S2、S3,我想创建一个这样的仿函数structmy_functor{templatevoidoperator()(x&el1,y&el2,z&el3){...}}然后调用for_each(s1,s2,s3,my_functor())//appliesthefunctortoallcombinationsofelementsofs1,s2,s3其中s1、s2、s3是S1、S2、S3的实例。我

c++ - 对于 CLang 中的 enable_if 错误(错误 11723)是否有更好的解决方法?

理想情况下,我们可以使用enable_if做类似的事情:#includenamespacedetail{enumclassenabler_t{DUMMY};}templateusingenable_if_u=typenamestd::enable_if::type;templateusingdisable_if_u=typenamestd::enable_if::type;template::value>...>inta(){return0;}template::value>...>doublea(){return0.0;}intmain(){autox=a();}恕我直言,这是最好的

C++ - 通过单个指针访问多个对象的接口(interface)

我需要存储一个对象指针容器。这些对象有一些我想要强制执行(可能在编译时)和使用的通用方法/属性(接口(interface))。示例:structA{voidfly(){}};structB{voidfly(){}};Aa;Bb;std::vectorobjects;objects.push_back(&a);objects.push_back(&b);for(auto&el:objects)el->fly();更简单的解决方案是A和B继承一个共同的基类,如FlyingClass:structFlyingClass{voidfly(){}};structA:publicFlyingCla

c++ - 打印给定类型名称的模板

出于调试目的,我想打印一个类型的名称,所以我创建了一个函数来实现这个目的(事实上,我从另一个SO答案中借用了它,但我现在找不到),该函数看起来像这样:templatestd::stringTypeName(T){autoname=typeid(T).name();intstatus=0;std::unique_ptrres{abi::__cxa_demangle(name,NULL,NULL,&status),std::free};return((status==0)?res.get():name);}LiveDemo它工作正常:inti=0;floatf=0.f;std::cout但

c++ - 任意顺序的多个标签的模板特化

假设我有一个像这样定义的类event_basetemplateclassevent_base{public:usingdelegate_type=std::function;usingid_type=size_t;protected:std::vector>m_funcs;};和一些像这样定义的空标签结构structmutable_tag{};structcallable_tag{};然后我希望能够基于模板包中给定的标签中的一个(或两个)从该基类派生对于单个标签:templateclassevent;templateclassevent:publicevent_base{};templ

c++ - 在宏中包装模板函数调用,或避免特化 void 返回

我有以下功能,允许我包装OpenGL命令并在出现问题时记录:templatestructChecker{staticResrun(conststd::string&function_name,Func&&func,Args&&...args){Resresult=func(std::forward(args)...);check_and_log_error(function_name);returnresult;}};templatestructChecker{staticvoidrun(conststd::string&function_name,Func&&func,Args&&.

c++ - 我怎样才能*有效地*从嵌套表达式生成所有类型的元组?

假设我有一些包含类型排列的模板表达式,在本例中它们来自AbstractSyntaxTree:templatestructBranch{};templatestructLeaf{};输入表达式可以是Branch的任意嵌套组合和Leaf类型,但为了简单起见,我将创建一个包含单个Leaf的线性AST包裹N层层深入Branch类型:usingExpression=Branch>;//N=2为了这个问题,我创建了一个函数来动态生成这些表达式,这样我就可以演示我在绘图方面遇到的问题。所以这里是我将用来生成我的表达式的函数://wrapLeafinBranchNnumberoftimes:templ