jjzjj

C++ CRTP 类层次结构

来自Wikipedia://TheCuriouslyRecurringTemplatePattern(CRTP)templatestructbase{//...};structderived:base{//...};现在如果我想要derived_from_derived,我可以写://TheCuriouslyRecurringTemplatePattern(CRTP)templatestructbase{//...};templatestructderived:base{//...};structderived_from_derived:derived{//...};现在假设我只想要一

c++ - 将 vector<shared_ptr<Derived>> 传递给需要 vector<shared_ptr<Base>> 的函数

我使用的代码结构有问题,如下(简化):classSPoint{public:SPoint(doublex,doubley,doublez):_x(x),_y(y),_z(z){}protected:double_x,_y,_z;}classPoint3D:publicSPoint{public:Point3D(doublex,doubley,doublez):SPoint(x,y,z){//defaultvaluesforUandV}protected:doubleU,V;}这些点用于创建折线:classSPolyline{public:SPolyline(constvector>&p

c++ - 派生类不能使用指向 protected 基类成员的成员指针

includeclassBase{protected:intfoo;intget_foo(){returnfoo;}};classDerived:publicBase{public:voidbar(){intBase::*i=&Base::foo;this->*i=7;printf("foois%d\n",get_foo());}};intmain(){Derivedd;d.bar();}我不明白为什么我的派生类型不能指向基类的protected成员。它有权访问该成员。它可以调用类似作用域的函数。为什么它不能创建一个成员指针?我正在使用gcc4.1.2,但出现此错误:test.cc:I

c++ - 是否可以通过删除基类中的复制构造函数/运算符来使派生类不可复制?

PreC++11,我问这是否可以使用私有(private)/未实现的技巧(参见here)。显然,这是不可能的。我想知道新的=delete语法是否改变了事态,因为强制派生类不可复制仍然是一个有用的特性。更新后的代码片段可能看起来像这样:classBase{public:Base(){}virtual~Base(){}Base(constBase&)=delete;Base&operator=(constBase&)=delete;virtualvoidinterfaceFunction()=0;//etc.//nodatamembers};classData{/*...*/};class

c++ - 当 Base 和 Derived 都使用 Derived 类型参数进行模板化时调用 Base 构造函数时出现编译器错误

我很难理解为什么以下代码无法编译:templateclassBase{public:Base(inta){}};templateclassDerived:publicBase{public:Derived(inta):Base(a){}};intmain(){}在我的编译器(gcc5.4.0withC++11)上输出错误信息error:class'Derived'doesnothaveanyfieldnamed'Base'Derived(inta):Base(a){}我看到这有点类似于Templatebaseconstructorcallinmemberinitializationli

c++ - C++ 中的虚拟析构函数与普通方法

考虑以下三个C++程序:节目1structbase{virtual~base()=0;};structderived:publicbase{~derived();};derived::~derived(){}intmain(){}节目2structbase{virtual~base()=0;};structderived:publicbase{~derived(){}};intmain(){}节目3structbase{virtualvoidfunc()=0;};structderived:publicbase{voidfunc();};voidderived::func(){}int

c++ - Derived from two Bases - 删除 vector **奇怪**问题

这个问题在这里已经有了答案:Whentousevirtualdestructors?(20个答案)关闭4年前。我花了几个小时试图找出问题出在哪里,但它看起来很奇怪。我以更容易理解的方式重写了我的问题。当它到达它说删除的行时,调试程序会创建一个断点。附言。有趣的是,如果我们采用intb1并将其移动到Base2,它就可以工作。基数1:#pragmaonceclassBase1{public:Base1();~Base1();intb1;};Base2.h:#pragmaonce#include#includeclassDerived;classBase2{public:Base2();~B

c++ - 接受特征密集矩阵和稀疏矩阵的函数

我正在努力为一个开源数学库添加稀疏矩阵支持,并且希望不要为Dense和Sparse矩阵类型提供重复的函数。下面的例子展示了一个add函数。一个具有两个功能的工作示例,然后是两次失败的尝试。下面提供了指向代码示例的Godbolt链接。我查看了关于编写采用Eigen类型的函数的Eigen文档,但他们使用Eigen::EigenBase的答案不起作用,因为MatrixBase和SparseMatrixBase具有EigenBase中不存在的特定方法https://eigen.tuxfamily.org/dox/TopicFunctionTakingEigenTypes.html我们使用C++

c++ - 是否使用非虚析构函数和基类指针释放了整个对象?

如果一个基类没有虚析构函数(例如为了避免vtable条目)并且派生类只有基本属性,它是否释放了new分配的所有内存,当基类的指针被删除?我知道Derived类的析构函数不会被调用,但我想知道整个对象分配的内存是否会被释放?我还假设在Derived指针上调用delete将释放整个内存空间。此外,如果它不释放内存的派生类部分,它如何在相同的情况下工作,但使用基类中的虚拟析构函数,知道要释放多少内存?例子:classBase{public:inta;intb;Base(){}~Base(){}};classDerived:publicBase{public:intc;intd;Derived

c++ - 如何初始化数组并将指针传递给派生的基构造函数?

完全重写了问题。请仔细阅读请注意不要让您感到困惑:基本构造函数需要指向常量数组的指针。它本身不存储指针,它存储数据!我有以下代码:classBase{public:Base(int*);//addedthistoexplainwhyIneedinheritancevirtualvoidabstractMethod()=0;};Base::Base(constint*array){//justforexamplecout我想对派生类的用户隐藏Base(int*)构造函数。为此,我需要为该数组提供默认值。问题是当我像这样使用初始化列表时:Derived::Derived():Base(ne