我正在做一个基于继承的赋值,我创建了两个构造函数,假设它们可以执行不同的操作。一个构造函数没有任何参数并且应该生成预定义的值,另一个构造函数有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但我不太清楚为什么。这是我第一次使用多个构造函数,所以我有点困惑,因为它有用,所以任何帮助都会非常感谢,谢谢。
答案 0 :(得分:3)
您的基类似乎是正确的,但您需要更改您的实现。
您的Wolf
和Carnivore
构造函数应为:
Wolf(String name, int age)
{
super(name, age);
}
原因是,您要为每种类型设置本地实例变量,但调用超类的getAge()
方法 - 这会获得超级{{{}的值1}},其值实际上并未在任何地方分配,并且默认值为 0 。这与age
相同,默认为 null 。
您需要使用传递的变量调用name
,并且不需要为每个扩展对象重新定义它们。