草庐IT

kotlin - 在父类(super class)型上键入的属性 getter ,而不是在 Kotlin 中的实现

假设我有两个类,一个Base和一个扩展Base的Impl。packagemypackageopenclassBaseclassImpl:Base()我将如何为具体的Impl-Type(供内部使用)创建一个私有(private)属性,并将publicgetter键入为Base-Type,实现多态?我最初的做法是这样的:classTest{privatevalmyType=Impl()get():Base}但是,Kotlin编译器提示:Error:(30,11)Kotlin:Getterreturntypemustbeequaltothetypeoftheproperty,即'mypack

c++ - 访问父类中的子成员,C++

我面临这样一种情况,我需要访问父类中的子成员变量。我知道这违反了OO原则,但我必须处理这样一种情况:数百个类继承自一个类,并且其中一半停止使用其中一个父变量,并声明并使用它们自己的(需要切换从int到int[]并且显然这样做的人没有考虑在父类中应用此更改)。一种选择是使用虚函数来处理它,但这意味着我必须更改数百个文件/对象中的代码并测试它们中的每一个。因此我想,如果可以使用一些老派的C指针魔术来访问父方法中的this变量,这将消除数百个虚函数的需要。基本上这就是我想要实现的目标:classParent{voidDoSomething(){//ThisiswhatIneedchildMe

c++ - 在 C++ 中是否有时不调用父类(super class)的构造函数?

这个问题让我参加了面试。如果B是A的子类。构造B时,有没有调用A的构造函数的时候?编辑:我告诉面试官我想不出这种情况,因为我认为只有在构造子类之前正确构造父类(superclass)才有意义。 最佳答案 一个可能的例子是同时A和B没有用户声明的构造函数和B的实例正在值初始化。A和B两者都有隐式声明的构造函数,不会在此初始化中使用。同样如果A没有用户声明的构造函数,但出现在B的构造函数的成员初始值设定项列表中但是用一个空的初始值设定项然后AB的构造函数将被值初始化用来。同样,因为A没有用户声明的构造函数值初始化不使用构造函数。

inheritance - 如何让数据类在 Kotlin 中实现接口(interface)/扩展父类(super class)属性?

我有几个数据类,其中包括varid:Int?字段。我想在interface或superclass中表达这一点,并让数据类扩展它并在构造时设置此id。但是,如果我尝试这样做:interfaceB{varid:Int?}dataclassA(varid:Int):B(id)它提示我正在覆盖id字段,我是哈哈..Q:在这种情况下,如何让数据类A在构造时获取一个id,并设置该id在interface或superclass中声明? 最佳答案 确实,您不需要abstractclass然而。您可以覆盖interface属性,例如:interfac

inheritance - 如何让数据类在 Kotlin 中实现接口(interface)/扩展父类(super class)属性?

我有几个数据类,其中包括varid:Int?字段。我想在interface或superclass中表达这一点,并让数据类扩展它并在构造时设置此id。但是,如果我尝试这样做:interfaceB{varid:Int?}dataclassA(varid:Int):B(id)它提示我正在覆盖id字段,我是哈哈..Q:在这种情况下,如何让数据类A在构造时获取一个id,并设置该id在interface或superclass中声明? 最佳答案 确实,您不需要abstractclass然而。您可以覆盖interface属性,例如:interfac

c++ - 将 std::variant 转换为另一个具有父类(super class)型集的 std::variant

我有一个std::variant,我想将其转换为另一个具有其类型超集的std::variant。有没有一种方法可以让我简单地将一个分配给另一个?templateToVariantConvertVariant(constFromVariant&from){ToVariantto=std::visit([](auto&&arg)->ToVariant{returnarg;},from);returnto;}intmain(){std::varianta;a=5;std::variantb;b=ConvertVariant(a);return0;}我希望能够简单地编写b=a来进行转换,而不是

c++ - QTimer::singleShot() 在给定对象的父类中查找指定的槽,而不是对象本身

我是Qt的新手。我对现有的Qt应用程序做了一些简单的修改,但我还没有从头开始创建任何应用程序。一般来说,我对C++的某些方面(类继承等)也没有太多经验。我创建了一个新的基于Code::BlocksQt4的项目并稍微修改了模板。我添加了两个文件。目前该项目包含三个文件:main.cpp、app.h和app.cpp。这是ma​​in.cpp的内容:#include#include"app.h"intmain(intargc,char*argv[]){TestAppapp(argc,argv);QTimer::singleShot(1000,&app,SLOT(timeout()));ret

java - 在 Kotlin 数据类中调用父类(super class)构造函数之前的访问函数

我在Kotlin中使用数据类来显着减少我必须编写的Java代码量。但是,在我的一个Java类中,我不确定如何在Kotlin中实现相同的结果。我的Java类看起来有点像这样:publicclassDataObject{privateintmId;privateStringmName;publicDataObject(intid,Stringname){mId=id;mName=name;}publicDataObject(Contextcontext,intid){mId=id;Cursorcursor=...cursor.moveToFirst();mName=cursor.getSt

java - 在 Kotlin 数据类中调用父类(super class)构造函数之前的访问函数

我在Kotlin中使用数据类来显着减少我必须编写的Java代码量。但是,在我的一个Java类中,我不确定如何在Kotlin中实现相同的结果。我的Java类看起来有点像这样:publicclassDataObject{privateintmId;privateStringmName;publicDataObject(intid,Stringname){mId=id;mName=name;}publicDataObject(Contextcontext,intid){mId=id;Cursorcursor=...cursor.moveToFirst();mName=cursor.getSt

c++ - 成员类可以从它的父类继承吗?

在考虑对一个奇怪问题的“创造性”(即奇怪的)解决方案时,一个特别的想法激发了我的好奇心。这不是我可能会使用的想法,但我仍然想知道根据标准它是否合法。一个简单的例子是...classbase_t{private://stuffpublic://morestuffclassderived_t:publicbase_t//部分奇怪-因为derived_t继承自包含derived_t的base_t,所以derived_t似乎包含本身。所以-这是一个与curiouslyrecurringtemplatepattern类似的有效但奇怪且可怕的东西吗?,还是违法的?编辑-我或许应该提一下,我想到这个