草庐IT

Derived1

全部标签

c++ - 为什么我不能将指向 Derived 类成员函数的指针强制转换为相同但属于 Base 类的成员函数?

对我来说,将void(Derived::*)()转换为void(Base::*)()看起来非常安全,如下所示代码:#include#includeusingnamespacestd;structBase{void(Base::*any_method)();voidcall_it(){(this->*any_method)();}};structDerived:publicBase{voida_method(){cout但是编译器在a.any_method=&Derived::a_method;处提示转换。这是防止细微编程错误的障碍,还是只是为了让编译器编写者的生活更轻松?是否有变通方法

c++ - CRTP 静态多态性 : Using the Base Class to Call Derived Methods

C++中virtual的主要好处之一是能够使用基类(指针或引用)调用派生方法。我正在阅读usingCRTPtoimplementstaticpolymorphism,但我不明白如何使用这种技术实现上面提到的内容,因为当需要模板时,我无法将函数声明为采用Base类型。在我看来,文章中描述的内容可以通过简单地使用函数重载来实现,所以我确信这种技术一定有更多。(PS:在对thisquestion的回答的评论中提到了这个确切的问题,但不幸的是没有人回复它:“vtables真正提供的是使用基类(指针或引用)来调用派生方法。你应该在这里展示它是如何用CRTP完成的。”)这是我的最小代码,它给出了错

c++ - 可以将具有 Base 类型的 STL 容器转换为 Derived 类型吗?

是否可以将STL容器从Base类型转换为Derived类型?例如,我有两个vector。第一个是基类类型,第二个是派生类类型。classBase{//Code};classDerive:publicBase{//Code};用法vector*vec_base=newvector;//AddsomeDerivetypedatatovec_basevector*vec_derive=(vector*)(vec_base);//UsingelementsasDerivepointers.Worksfine.这样可以吗?(它工作正常,但我想对此发表一些评论)。非常感谢你。编辑:根据答案更新。说

C++ : Initializing base class constant static variable with different value in derived class?

我有一个带有常量静态变量a的基类A。我需要类B的实例对静态变量a具有不同的值。这怎么能实现,最好是静态初始化?classA{public:staticconstinta;};constintA::a=1;classB:publicA{//???//Howtoset*a*toavaluespecifictoinstancesofclassB?}; 最佳答案 你不能。所有派生类共享一个静态变量实例。 关于C++:Initializingbaseclassconstantstaticvaria

c++ - 调用派生类的模板函数

我在C++中遇到一个问题,即在具有指向基类的指针时调用派生类的函数。编辑:一些答案让我引用了CRTP但我的观点是我需要一个指向“Base*”类而不是“Base*”的指针,因为我不知道当前正在处理的类型(当前实例是从某种工厂创建的).类:classBase{..templatefunc(Targ){...};};classDerived1:publicBase{...templatefunc(Targ){...};};classDerived1:publicBase{...templatefunc(Targ){...};};用法:intmain(){Base*BasePtr=newDer

c++ - 如果 Derived 不向 Base 添加新成员(并且是 POD),那么可以安全地完成什么样的指针转换和取消引用?

(这是关于未定义行为(UB)的另一个问题。如果这段代码在某些编译器上“有效”,那么这在UB领域就没有任何意义。这是可以理解的。但是我们到底在下面的哪一行跨入UB?)(关于SO已经有很多非常相似的问题,例如(1)但我很好奇在取消引用指针之前可以安全地使用指针做什么。)从一个非常简单的基类开始。没有virtual方法。无继承。(也许这可以扩展到任何POD?)structBase{intfirst;doublesecond;};然后是添加(非virtual)方法但不添加任何成员的简单扩展。没有virtual继承。structDerived:publicBase{intfoo(){return

c++ - 移动构造函数和赋值运算符 : why no default for derived classes?

为什么没有为派生类创建默认移动构造函数或赋值运算符?证明我的意思;具有此设置代码:#includestructA{A(){}A(A&&){throw0;}A&operator=(A&&){throw0;}};structB:A{};以下任一行抛出:Ax(std::move(A());Ax;x=A();但以下都没有:Bx(std::move(B());Bx;x=B();以防万一,我使用GCC4.4进行了测试。编辑:后来使用GCC4.5进行的测试显示了相同的行为。 最佳答案 通读0xFCD中的12.8(12.8/17特别是移动构造函数)

c++ - 调用 ~Derived() 和 ~Base() 之间的对象状态

问题C++标准对一个对象在时间上的状态有什么保证在派生类的析构函数执行之后,但在基类的析构函数执行之前?(此时派生类的子对象的析构函数被调用。)例子#includestructBase;structMember{Member(Base*b);~Member();Base*b_;};structBase{virtualvoidf(){}virtual~Base(){}};structDerived:Base{Derived():m(this){}virtual~Derived(){}virtualvoidf(){}std::strings;Memberm;};Member::Member

c++ - 派生类调用时的虚函数性能?

如果在编译时从已知为派生类的类调用虚拟方法,是否会导致性能下降?下面我使用派生类显式调用force_speak。代码:#include#include#includeclassBase{public:virtualvoidspeak(){std::coutvoidforce_speak(std::array,3>&arr){for(auto&b:arr){b->speak();}}intmain(){std::array,3>arr={std::unique_ptr(newDerived1),std::unique_ptr(newDerived1),std::unique_ptr(ne

c++ - 我不明白为什么 'Derived1' 需要与 'Derived3' 相同的内存量

在下面的代码中,我不明白为什么“Derived1”需要与“Derived3”相同的内存量。另外Derived4的size为16有没有什么特殊意义。#includeusingnamespacestd;classEmpty{};classDerived1:publicEmpty{};classDerived2:virtualpublicEmpty{};classDerived3:publicEmpty{charc;};classDerived4:virtualpublicEmpty{charc;};classDummy{charc;};intmain(){cout这段代码的输出是:size