草庐IT

Templates

全部标签

c++ - 在 friend 类模板的基本子句中访问私有(private)定义

在C++中,使类模板B的基类规范依赖于与类模板是friend的类A的私有(private)定义是否合法>B?示例代码:structEmpty{};templatestructB;structA{friendstructB;private:usingBase=Empty;};templatestructB:T::Base{};intmain(){Btest;return0;}Godbolt链接:https://godbolt.org/g/HFKaTQ代码在Clang主干(和旧版本)和MSVC19(VS2017)上编译良好,但在GCC主干(和旧版本)上编译失败:test.cpp:Inins

c++ - 显式转换运算符模板的优先级和歧义

我一直在我的项目中使用模板化的显式转换运算符,以实现从自定义类变体类型的显式转换。重现我的问题的最小示例如下所示(在C++14模式下):#include#include#includeusingnamespacestd;classA{public:templateexplicitoperatorT()const//1{coutexplicitoperatorconstT&()const//2{coutexplicitoperatorT&()//3{cout(a)-3.14)我遇到的问题是为static_cast转换选择的运算符。对于GCC,这是一种预期的(1)情况。输出是:operat

c++ - constexpr if 和 static_assert

P0292R1constexprif一直included,在C++17的轨道上。它似乎很有用(并且可以替代SFINAE的使用),但是关于static_assert的评论是错误的,不需要诊断在false分支中吓到我了:Disarmingstatic_assertdeclarationsinthenon-takenbranchofaconstexprifisnotproposed.voidf(){ifconstexpr(false)static_assert(false);//ill-formed}templatevoidg(){ifconstexpr(false)static_asser

c++ - 关于成员函数指针值的 Constexpr - 未定义的行为?

我对C++中类似机制的简单反射有疑问。我想要一种模板类型,它应该以不同的成员函数指针作为模板参数表现不同:[解决方案#1,按标准来说是不好的]如果我有一个带有类类型及其成员函数指针的类模板,我不能部分特化为null的成员指针,因为我不能特化“具有依赖类型的非类型模板参数”(参见:https://en.cppreference.com/w/cpp/language/partial_specialization参数列表[5])templatestructp{};templatestructp{};[解决方案#2,GCC问题]如果我尝试专注于一个推导的constexpr值,它反射(refle

c++ - 模板类中的模板成员特化

#include#includetemplatestructA{templateautofunc();templateautofunc();};templatetemplateautoA::func(){returnstd::string{"foo"};}intmain(){Aa{};std::cout()这不起作用,因为模板类的模板成员的特化是不可能的,除非您也特化该类。(我读到过。)但是如果您将成员特化的定义移动到类定义中,它确实有效:#include#includetemplatestructA{templateautofunc();templateautofunc(){retu

c++ - 如何为任意(但在编译时定义)功能支持定义抽象基类?

我有以下C++设计问题,非常感谢任何建议/解决方案。请注意,我的背景不是计算机科学,因此我可能缺少一些明显的解决方案。我通常在代码中分离关键组件的方式是通过抽象类和纯虚函数定义接口(interface)。范例1:classB{public:virtualdoublef(doublex)=0;};classD1:publicB{public:doublef(doublex)const{return0.0;}};classD2:publicB{public:doublef(doublex)const{return1.0;}};这样我就可以很好地将接口(interface)与实现分开。这种方

c++ - 专门针对 const 成员函数指针

我正在尝试将一些实用程序代码专门用于const成员函数,但在让简单的测试用例工作时遇到问题。为了简化工作,我正在使用Boost.FunctionTypes及其components模板-应该是contain的MPL序列标签const_qualified对于const成员函数。但是使用下面的测试代码,常量成员函数的特化失败了。有人知道如何让它发挥作用吗?测试代码打印出来(使用VC8和boost1.40):non-constnon-const预期输出是:non-constconst测试代码本身:#include#include#include#include#includenamespace

c++ - 模板类容器自动转换问题

我有以下代码:#includetemplateclassfixed{public:explicitfixed(doubleval=0){operator=(val);}~fixed(){}operatordouble()const{returnv_;}doubleoperator=(constdouble&d){if(d>Wt)v_=Wt;elsev_=d;returnv_;}private:doublev_;};intmain(){fixedx;std::vector>v(5);//std::vector>v(5,0);//fixedy;//v[0]=0;x=x*v[0];}在VS2

c++ - 继承一个带有内部类的模板类,并在继承类中访问内部类

我有一个模板类“BinaryHeap”,它还在自身内部声明了一个公共(public)类“Item”。现在我想用用于元素查找的散列扩展BinaryHeap,因此继承了它。我将其称为“HashedBinaryHeap”,它应该使用与BinaryHeap相同的Item类。stub看起来像这样:templateclassBinaryHeap{public:classItem{...};...voidappendItem(constItem&item);...};templateclassHashedBinaryHeap:publicBinaryHeap{public:...voidappend

c++ - 如何通过继承专门化复杂模板 - C++

我似乎找不到合适的语法来特化这个模板:templateclassTSin:publicBasicTween{...我想保留作为模板参数,但特化所有其他参数。我正在尝试这样:templateclassTSin{...这会产生错误。有人可以提供正确的语法来专门化模板和实例化专门版本的语法吗? 最佳答案 我认为您的代码应该如下所示:http://ideone.com/cvGy3您需要为类实例化定义所有类型。 关于c++-如何通过继承专门化复杂模板-C++,我们在StackOverflow上找到