这个问题在这里已经有了答案:Whyissuper.super.method();notallowedinJava?(22个答案)关闭9年前。publicclassGrandParent{publicvoidwalk(){...}}publicclassParent{publicvoidwalk(){...}}publicclassChild{publicvoidwalk(){//HereinsomecasesIwanttousewalkmethodofGrandParentclass}}现在在Child.walk()中,我只想在某些情况下使用GrandParent.walk()。我怎样
我想检查一个类对象是否代表其他类的子类例如Classclass1=Class.forName("Class1");Classclass2=Class.forName("Class2");if(class1.isSubClassOf(class2))//fakemethosisSubClassOf{//dosth}如何实现这个isSubClassOf方法? 最佳答案 Class.isAssignableFrom()或多或少提供了您想要的东西,尽管它也处理接口(interface),因此可能需要做更多的额外工作以确保它是一个子类,无论是
如何使用Mockito或PowerMock模拟一个由子类实现但继承自抽象父类(superclass)的protected方法?换句话说,我想在模拟“doSomethingElse”的同时测试“doSomething”方法。抽象父类(superclass)publicabstractclassTypeA{publicvoiddoSomething(){//CallsforsubclassbehaviordoSomethingElse();}protectedabstractStringdoSomethingElse();}子类实现publicclassTypeBextendsTypeA{
我有一个私有(private)的枚举,不会在类外公开。无论如何我可以做那种类型的静态导入,这样我就不必每次都输入枚举类型了吗?或者有更好的写法吗?示例:packagekip.test;importstatickip.test.Test.MyEnum.*;//compileerrorpublicclassTest{privatestaticenumMyEnum{DOG,CAT}publicstaticvoidmain(String[]args){MyEnumdog=MyEnum.DOG;//thisworksbutIdon'twanttotype"MyEnum"MyEnumcat=CAT
简而言之,这是如何以及为什么可能的:Objectobj=newMyClass();Object是所有对象的父类(superclass),因此MyClass是Object的子类。一般来说,在Java中,为什么可以在父类中使用子类的构造函数?我明白它怎么可能反过来,因为子类拥有父类的所有变量/方法,所以当你初始化它们时,你只是在初始化父构造函数中指定的变量,这些变量按定义存在于child。问题是,当你反过来时,它不一定是真的。子项可以拥有父项没有的变量,那么当父项一开始甚至没有变量时,如何将子项构造函数与父项一起使用?这个特性在开发中有什么用?我想如果你想要一个B类的实例,你会把它声明为B
这可能是一件坏事,如CanparentandchildclassinJavahavesameinstancevariable?中所讨论的那样.(如果更改父变量名称怎么办?那么它将不再被隐藏。)但是,我仍然很好奇静态/非静态不同的变量是否会相互隐藏。一方面,我希望它们是相同的变量名,因此会被隐藏,但另一方面,编译器似乎可能会根据静态来区分两者。 最佳答案 根据Java语言规范:如果该类声明了一个具有特定名称的字段,则该字段的声明被认为隐藏了父类(superclass)和该类的超接口(interface)中具有相同名称的任何和所有可访问
以下可以吗?(请记住,我没有编写类的主体,也没有编写接口(interface);-))abstractclassSuperClassimplementsSuperInterfaceclassSubClassextendsSuperClassimplementsSubInterface或者这通常被认为是不好的做法?让我感到奇怪的是,以下内容不起作用:ListmyList;...for(SuperInterfacesi:myList){...} 最佳答案 不好也不坏。SubClass在这里实现了SuperInterface和SubInt
我正在维护一些Java8代码,如下所示:ClassEntity{protectedModeltheModel;publicEntity(){init();}protectedvoidinit(){this.theModel=newModel();}}ClassModel{}ClassSubModelextendsModel{}main{EntitynewEntity=newEntity(){@Overrideprotectedvoidinit(){this.theModel=newSubModel();}};}代码目前可以正确编译和运行,但我现在需要更新它。我的问题是:在newEnti
我(在某处)读到,当子类被垃圾回收时,不能保证调用父类的finalize(),这是否意味着大多数开发人员会覆盖finalize()在子类中调用super.finalize()? 最佳答案 Finalize不会自动为父类(superclass)调用。因此,如果您重写finalize,确保父类(superclass)得到清理的正确方法是protectedvoidfinalize(){try{//dosubclasscleanup}finally{super.finalize();}}请参阅这篇引用文章http://www.ibm.com
我目前正在Java中进行基于文本的冒险,目的是将其用作测试平台,以尝试从我正在阅读的这本Java书中学到的新东西。我现在正在尝试声明一个子类的实例(因为玩家被编写脚本来找到它)。父类是Item,它有两个子类:Weapon和Armour。但是,无论我尝试以何种方式声明它,我使用的IDE(Eclipse)都会标记该行并出现以下错误:NoenclosinginstanceoftypeItemisaccessible.MustqualifytheallocationwithanenclosinginstanceoftypeItem(e.g.x.newA()wherexisaninstanceo