Вызов метода подкласса из суперкласса

Я на начальном курсе Java, и мы только начали изучать наследование. Я работаю над задачей, которая требует, чтобы мы создали "Pet" суперкласс с именем и возрастом; и три подкласса, каждый со своей уникальной чертой (я выбрал «Собака», «Кошка» и «Птица»). После того, как мы собрали все это, мы должны создать класс Main для тестирования всего, и именно здесь я сталкиваюсь с проблемами. Я пытаюсь позвонитьget методы для этих уникальных черт вMain, но, кажется, найти только методы, которые находятся в суперклассе.

Вот основной класс:

<code>public class Kennel {
    public static void main(String[] args) {
        // Create the pet objects
        Pet cat = new Cat("Feline", 12, "Orange");
        Pet dog = new Dog("Spot", 14, "Dalmation");
        Pet bird = new Bird("Feathers", 56, 12);

        // Print out the status of the animals
        System.out.println("I have a cat named " + cat.getName()
                + ". He is " + cat.getAge() + " years old."
                + " He is " + cat.getColor()
                + "When he speaks he says " + cat.speak());
        System.out.println("I also have a dog named " + dog.getName()
                + ". He is " + dog.getAge() + " years old."
                + " He is a " + dog.getBreed()
                + " When he speaks he says " + dog.speak());
        System.out.println("And Finally I have a bird named " 
                + bird.getName() + ". He is " + bird.getAge() + " years old."
                + " He has a wingspan of " + bird.getWingspan() + " inches."
                + " When he speaks he says " + bird.speak());       
    }
}
</code>

Вот мой суперкласс

<code>abstract public class Pet {
    private String name;
    private int age;

    // Constructor
    public Pet(String petName, int petAge) {
        this.name = petName;
        this.age = petAge;
    }

    // Getters
    public String getName() { return(this.name); }
    public int getAge() { return(this.age); }

    // Setters
    public void setName(String nameSet) { this.name = nameSet; }
    public void setAge(int ageSet) { this.age = ageSet; }

    // Other Methods
    abstract public String speak();

    // toString
    @Override
    public String toString() {
        String answer = "Name: " + this.name + " Age: " + this.age;
        return answer;
    }
}
</code>

А вот один из подклассов (все они выглядят одинаково и имеют одинаковую ошибку)

<code>public class Cat extends Pet {
    private String color;

    // Constructor
    public Cat(String petName, int petAge, String petColor) {
        super(petName, petAge);
        this.color = petColor;
    }

    // Getters
    public String getColor() { return(this.color); }

    // Setters
    public void setColor(String colorSet) { this.color = colorSet; }

    // Other Methods
    @Override
    public String speak() { return "Meow!"; } 

    // toString
    @Override
    public String toString() {
        String answer = "Name: " + super.getName() + " Age: "+super.getAge()
                + " Color: " + this.color;
        return answer;
    }
}
</code>

Итак, что происходит, я не могу получить основной метод, чтобы найтиcat.getColor() метод, или любой из других уникальных для подклассов.

 salxander05 апр. 2012 г., 03:48
Это прояснилось, спасибо!
 twain24905 апр. 2012 г., 03:46
в чем ошибка? Я считаю, что вы должны разыграть это, так как вы сделалиPet cat = new Cat(... вместоCat cat = new Cat(....

Ответы на вопрос(4)

Pet cat = new Cat("Feline",12,"Orange");
^^^
This is the error.

Pet не имеет метода с именемgetColor()

Вам нужно сделать:

Cat cat = new Cat(...);

Здесь вы пытаетесь создать объект типа Superclass (cat) с помощью конструктора (Cat), который является методом подкласса, что невозможно. это нарушает правило наследования.

Pet cat = new Cat("Feline", 12, "Orange");

Решение Вопроса

Когда вы объявляете переменную как имеющую тип суперкласса, вы можете получить доступ только к (общедоступным) методам и переменным-членам суперкласса через эту переменную.

Pet cat = new Cat("Feline",12,"Orange"); 
cat.getName(); // this is OK
cat.getColor(); // this is not OK, getColor() is not in Pet

Для доступа к методам в конкретном классе (Cat в этом случае), вам нужно либо объявить переменную как производный класс

Cat cat = new Cat("Feline",12,"Orange"); 
cat.getName(); // OK, getName() is part of Cat (and the superclass)
cat.getColor(); // OK, getColor() is part of Cat

Или приведите его к типу, который вы знаете / подозреваемый является конкретным типом

Pet cat = new Cat("Feline",12,"Orange"); 
((Cat)cat).getName(); // OK (same as above)
((Cat)cat).getColor(); // now we are looking at cat through the glass of Cat

Вы даже можете объединить два метода:

Pet pet = new Cat("Feline",12,"Orange"); 
Cat cat = (Cat)pet;
cat.getName(); // OK
cat.getColor(); // OK
 24 мая 2017 г., 21:12
Это спасло мою жизнь
 05 апр. 2012 г., 03:56
Удалил мой, потому что это более полная и полностью правильная версия.

Когда вы делаете это:

 Pet cat = new Cat("Feline",12,"Orange");

Компилятор видит переменную cat как Pet. Таким образом, вы не можете использовать конкретный метод Cat classe.

Вы должны объявить cat как Type Cat, чтобы решить вашу проблему.

С уважением.

Ваш ответ на вопрос