草庐IT

c++ - 覆盖子类中的 Qt 插槽

我有一个基类,它定义了一个Qt插槽classBase{public:Base(){connect(otherobject,SIGNAL(mySignal),this,SLOT(mySlot));}publicslots:virtualvoidmySlot(){}}子类A只是实现了一些其他的东西。子类B覆盖插槽classSubB:Base{public:SubB():Base(){//Necessary?connect(otherobject,SIGNAL(mySignal),this,SLOT(mySlot));}publicslots:virtualvoidmySlot()overr

c++ - Qt/C++ 在没有子类化的情况下重写函数

我想覆盖QWidget的虚函数而不对其进行子类化。在java中是可能的。我找到了这个链接:overridingmethodswithoutsubclassinginJava不确定C++中是否也有方法。有什么想法吗? 最佳答案 没有继承就不能覆盖。链接示例中的代码进行子类化。也许混淆来自于它不使用extends关键字的事实。它创建了XStream的匿名子类并覆盖了它的方法。这样的类也存在于C++中,类似的代码也是可能的。命名约定有点不同。没有名称但有命名实例的类称为未命名†。以下是我对代码的音译,以展示如何在C++中使用未命名类来完成

c++ - 制作不同子类实例的 vector

尝试搜索,没有返回(我认为)。是否可以制作一个抽象类的vector?例如,我有父类(superclass)Unit。我有士兵、车辆和轰炸机子类。但是我想要一个vector中的任何子类的实例,例如vectorUnitList可以包含士兵和车辆的实例吗?这可能吗?如果有帮助,我会使用C++。 最佳答案 是的,但是您需要使用指针或智能指针(我会选择这个)。structX{virtual~X(){}//a;a.push_back(newY);a[0]->foo();for(inti=0;i不要忘记删除分配的内存。为什么不能使用实际对象:假设

c++ - 模板基类的子类的模板特化

这个问题有点难以解释,所以我先举个例子:我有一个类模板,它接受一个类型和一个整数常量作为模板参数,并且我有一些子类派生自该模板的实例化:templatestructBase{staticvoiddoSomething(){cout{};我想将这些类与一些其他模板(我们称之为测试)一起使用,这些模板具有针对不同类型的专门化。因为从Base的任何实例派生的所有类的行为应该完全相同,所以我只想定义一个Test特化来处理所有从Base派生的类。我知道我不能直接专门针对Base因为这不会检测到子类。相反,我的第一种方法是使用Boost的enable_if和类型特征://emptybodytotr

c++ - 更改现有对象 "on the fly"的 VTBL,动态子类化

考虑以下设置。基类:classThing{intf1;intf2;Thing(NO_INIT){}Thing(intn1=0,intn2=0):f1(n1),f2(n2){}virtual~Thing(){}virtualvoiddoAction1(){}virtualconstchar*type_name(){return"Thing";}}和派生类不同仅通过上述方法的实现:classSummator{Summator(NO_INIT):Thing(NO_INIT){}virtualvoiddoAction1()override{f1+=f2;}virtualconstchar*ty

c++ - 即使没有子类重写一个方法,它也会被虚拟调用吗?

假设您有以下类:classA{public:virtualvoidprint(){printf("A\n");}};classB:publicA{public:virtualvoidprint()override{printf("B\n");}};classC:publicB{//nooverrideofprint};现在,如果您创建B的实例并调用print:B*b=newB;b->print();这个方法会被虚调用吗?换言之,具体调用的方法是在编译时还是运行时确定的?理论上它可以在编译时确定,因为我们知道,B的子类都不会覆盖该方法,所以无论我将什么分配给指向B的指针B*b=newC;

c++ - 子类,赋值运算符重载?

如果我有以下类(class):classTestA{public:constTestA&operator=(constintA){return*this;}};classTestB:publicTestA{public://Inheritance?};问题假定类TestA和类TestB在变量方面具有完全相同的内容:赋值运算符(或任何其他运算符)是否被继承?以下是否有效?classTestB:publicTestA{public:usingTestA::operator=;//Inheritance?};如果有效,会有什么不同吗? 最佳答案

c++ - 用子类对象初始化的多态基类对象数组

抱歉,标题太复杂了。我有这样的东西:classBase{public:intSomeMember;Base():SomeMember(42){}virtualintGet(){returnSomeMember;}};classChildA:publicBase{public:virtualintGet(){returnSomeMember*2;}};classChildB:publicBase{public:virtualintGet(){returnSomeMember/2;}};classChildC:publicBase{public:virtualintGet(){return

c++ - 从子类到父类(super class)再到子类的转换?

我的程序需要处理不同种类的“笔记”:NoteShort,NoteLong...不同种类的笔记应该以不同的方式显示在GUI中。我为这些笔记定义了一个基类,叫做NoteBase.我将这些笔记存储在XML中;我有一个从XML文件读取并将笔记数据存储在vectorlist中的类.然后我发现我无法获取它们自己的类型,因为它们已经转换为NoteBase*!虽然if(dynamic_cast(ptr)!=NULL){...}可能有效,它真的太丑了。实现函数取NoteShort*或NoteLong*作为参数不起作用。那么,有什么好的方法可以解决这个问题吗?更新:谢谢大家的回复。我认为这也不应该发生——

c++ - 如何在子类(C++)中专门化模板方法?

我正在尝试在其子类中专门化非模板类的模板方法://.h文件classMyWriter{public:templatevoidtest(constT&val){std::cout//.cpp文件classMyType{public:MyType(intaa,doubledd):a(aa),d(dd){}inta;doubled;};classMyWriterExt:publicMyWriter{public:templatevoidtest(constMyType&val){test(val.a);test(val.d);}};intmain(){MyWriterExtw;w.test(