我有以下结构:classBar{....protectedvoidrestore(){....}....}这个类由Foo扩展如下:classFooextendsBar{....@Overridepublicvoidrestore(){//validoverridesuper.restore();....}}在我的jUnit测试中,我想测试当调用foo.restore()时,随后调用super.restore()。因此,下面是我的jUnit测试方法:classFooTest{@TestedFoo_foo;@TestvoidtestRestore(finalBarbar){newExpec
据我所知,使用上限泛型和使用父类(superclass)作为方法参数都接受相同的可能参数。哪个是首选,两者之间有什么区别(如果有)?上限泛型作为参数:publicvoiddoSomething(Tfoo){}父类(superclass)作为参数:publicvoiddoSomething(Foofoo){} 最佳答案 这是一个上限类型参数。使用super创建下限,你不能真正为类型参数做。Youcan'thavealowerboundedtypeparameter.这会有所不同,例如,如果您想要传递List.因此,对于以下两种方法:p
我知道措辞有点困惑和奇怪,但请耐心等待,我不知道如何用更短的措词来表达。假设你有一个名为SuperBlah的类,你在一个名为Blah的类中继承了它,然后你将Blah继承到一个名为ChildBlah(所以SuperBlah-Blah-ChildBlah)。如果Blah没有构造函数?对于那些拒绝的人,那为什么这有效?我们有一个名为BlusterBug的类,它扩展了Critter类,并在BlusterBug的构造函数中调用了super。Critter没有构造函数,但Critter扩展的类有构造函数。(我故意省略了类的其余代码)publicclassBlusterCritterextendsC
我有一个带有方法的抽象父类(superclass)AdoSomething().A的子类必须实现doSomething(),但也有一些公共(public)代码应该在每次子类调用时调用doSomething().我知道这可以这样实现:publicclassA{publicvoiddoSomething(){//Thingsthateverysub-classshoulddo}}publicclassBextendsA{publicvoiddoSomething(){super.doSomething();//Doingclass-B-specificstuffhere...}}虽然这似乎
我已经做了一些搜索,但我要么没有问正确的问题,要么没有记错。无论如何,在Java中,我想知道是否可以将父类(superclass)对象作为参数传递给子类,以及使该对象的数据可用于该类的父类(superclass)的最有效方法是什么。代码示例:publicclasssuperclass{Stringmyparm1;StringmyParm2;intmyParmN;publicsuperclass(Stringp1,Stringp2,intpn){this.myparm1=p1;this.myparm2=p2;this.myParmN=pn;}//othermethodshere}publ
我正在将一个项目迁移到Java9,在我切换到新的Java版本后测试开始失败,似乎PowerMock正在尝试访问它无法访问的一些类。Testsrun:1,Failures:0,Errors:1,Skipped:0,Timeelapsed:0.973secmaven-surefire-pluginmaven-surefire-plugin2.19.1**/*Test.java**/*Test.groovy**/*Spec.*always--add-modulesjava.xml.bind--add-modulesjava.activation--add-opens=java.base/
我想像这样写一个交互器:classPlant{}classTreeextendsPlant{}classMapleextendsTree{}//Iteratorclass:compilererrorontheword"super".classMyIteratorimplementsIterator{privateintindex=0;privateListlist=//Getthelistfromanexternalsource.publicTnext(){Maplemaple=list.get(index++);//Dosomeprocessing.returnmaple;}//Th
我目前正在探索Guice功能并遇到了一个奇怪的行为-当我将变量声明为@Inject@Named("dragon")Dragondragon2;注入(inject)按预期工作,但是当我想将dragon2声明为接口(interface)(它实现Creature)时,我。e.@Inject@Named("dragon")Creaturedragon2;我得到一个错误未绑定(bind)带有@com.google.inject.name.Named(value=dragon)注释的warlock.rincewind.creatures.Creature的实现。这是我的提供者方法:@Named("
我正在尝试重构一个项目,其中有相同的方法分布在各个类中。为了减少代码重复,我应该将公共(public)代码移到抽象父类(superclass)中,还是应该将其放在实用程序类的静态方法中?编辑有些方法适用于我认为可以静态化的通用内容。虽然还有其他引用类的属性,但在这种情况下,我认为将其作为抽象父类(superclass)更有意义。 最佳答案 好吧,我遵循一个规则:不要使用基类来删除代码重复,使用实用类。对于继承,问自己一个问题:是否存在Is-A关系?另一个在大多数情况下都是正确的规则是:优先使用组合而不是继承使用静态实用程序类不是真正
我在这个类中没有发现任何错误,但Netbeans在那个类中不断显示红色符号。类是/**Tochangethistemplate,chooseTools|Templates*andopenthetemplateintheeditor.*/packageea;/****@authorriyad*/importjava.util.Random;importjava.util.BitSet;publicclassIndividual{BitSetvariable;doublex;doublefitness;doublesharedFitness;finalintSIZE;Randomgener