3

我正在做一个基于继承的分配,我创建了 2 个构造函数,它们应该做不同的事情。一个构造函数没有任何参数并且应该产生一个预定义的值,另一个构造函数有 2 个参数,这些参数由 String 和 int 类型的名称和年龄组成。我以某种方式重新配置了两个构造函数,以使它们都不会产生它们应有的结果。以下是调用这些构造函数的类:

动物(超类)

abstract public class Animal implements Comparable<Animal>
{
    int age;
    String name;

    Animal(String name, int age)   
    {
        this.age = age;
        this.name = name;
    } 

    Animal()
    {   
         this("newborn", 0);
    }        

    public int getAge()
    {
         return age;
    }

    public void setName(String newName)
    {
        name = newName;
    }

    String getName()
    {
        return name;
    }
}

肉食动物

public class Carnivore extends Animal
{
    Carnivore(String name, int age)   
    {
        this.age = age;
        this.name = name;
    }

    Carnivore()
    {
        super();
    }

    @Override
    public int compareTo(Animal o)
    {
        //To change body of generated methods, choose Tools | Templates.
        throw new UnsupportedOperationException("Not supported yet."); 
    }
}

public class Wolf extends Carnivore
{
    String name;
    int age;

    Wolf(String name, int age)   
    {  
        this.name = name;
        this.age = age;
    }

    Wolf()
    {
        super();
    }   

    String getName()
    {
        return name;
    }
}

主要方法

System.out.println("************1st constructor of Wolf************");
Wolf wolfExample = new Wolf("Bob", 2) {};        
System.out.println("Name = " + wolfExample.getName());
System.out.println("Age = " + wolfExample.getAge());

System.out.println("************2nd constructor of Wolf************");    
Wolf newWolf = new Wolf();
System.out.println("Name = " + newWolf.getName());
System.out.println("Age = " + newWolf.getAge());

实际输出

************1st constructor of Wolf************
Name = Bob
Age = 0
************2nd constructor of Wolf************
Name = null
Age = 0

预期产出

************1st constructor of Wolf************
Name = Bob
Age = 2
************2nd constructor of Wolf************
Name = newborn
Age = 0

年龄正在返回它们的默认值,第二个构造函数的名称也返回 null 但我不太清楚为什么。这是我第一次使用多个构造函数,所以我对它的工作原理有点困惑,所以非常感谢任何帮助,谢谢。

4

1 回答 1

3

您的基类似乎是正确的,但您需要更改您的实现。

WolfCarnivore构造函数应该是:

Wolf(String name, int age)   
{
    super(name, age);
}

原因是,您正在为每种类型设置局部getAge()实例变量,但调用超类的方法 - 这是获取超类的值age,其值实际上并未分配到任何地方,并被赋予默认值0。这对于name默认为null也是如此。

您需要super使用传递的变量进行调用,并且不需要为每个扩展对象重新定义它们。

于 2016-11-28T06:04:19.953 回答