Maison  >  Article  >  Java  >  Introduction à la conversion de type d'objets en Java (avec code)

Introduction à la conversion de type d'objets en Java (avec code)

不言
不言avant
2018-10-15 15:27:332870parcourir

Cet article vous présente une introduction à la conversion de type d'objet en Java (avec du code). Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer.

Transformation vers le haut : les objets de sous-classe sont convertis en classes parents et la classe parent peut être une interface. Formule : Père f = new Son(); Père est la classe ou l'interface parent et fils est la sous-classe.

Transformation vers le bas : l'objet classe parent est converti en sous-classe. Formule : Son s = (Son)f;

Nous définissons les paramètres formels sur le type Animal de la classe parent Lors de l'exécution de test.f(c), la situation de mémoire est. comme indiqué ci-dessous :

c est transmis en tant que type Cat et Animal a est utilisé comme paramètre formel, ce qui équivaut à exécuter Animal a = new Cat(). À ce stade, a et c pointent vers l'objet Cat en même temps, mais à ce moment, a ne peut pas accéder aux données membres étendues par la classe Cat, il suffit donc de forcer a dans le type Cat. S'il n'existe pas un tel mécanisme de transformation, nous devrons écrire deux fonctions f(Cat c) et f(Dog d) respectivement pour les chats et les chiens. Mais en fait, l’évolutivité du programme ci-dessus n’est pas la meilleure. Nous pouvons également utiliser la liaison dynamique (c'est-à-dire le polymorphisme) pour améliorer encore l'évolutivité. Les trois prémisses du mécanisme polymorphe sont : (1) l'héritage est requis, (2) la réécriture est requise, c'est-à-dire que la sous-classe redéfinit certaines méthodes dans la classe parent, et (3) une transformation vers le haut est requise, en utilisant les références de la classe parent à pointez vers un objet de sous-classe. Regardons un exemple :

class Animal {
    private String name;
    /**
     * 在Animal类自定义的构造方法
     * @param name
     */
    Animal(String name) {
        this.name = name;
    }

    /**
     * 在Animal类里面自定义一个方法enjoy
     */
    public void enjoy() {
        System.out.println("动物的叫声……");
    }
}

class Cat extends Animal {
    private String eyesColor;

    /**
     * 在子类Cat里面定义Cat类的构造方法
     * @param n
     * @param c
     */
    Cat(String n, String c) {
        /**
         * 在构造方法的实现里面首先使用super调用父类Animal的构造方法Animal(String name)。
         * 把子类对象里面的父类对象先造出来。
         */
        super(n);
        eyesColor = c;
    }

    /**
     * 子类Cat对从父类Animal继承下来的enjoy方法不满意,在这里重写了enjoy方法。
     */
    public void enjoy() {
        System.out.println("我养的猫高兴地叫了一声……");
    }
}

/**
 * 子类Dog从父类Animal继承下来,Dog类拥有了Animal类所有的属性和方法。
 * @author gacl
 *
 */
class Dog extends Animal {
    /**
     * 在子类Dog里面定义自己的私有成员变量
     */
    private String furColor;

    /**
     * 在子类Dog里面定义Dog类的构造方法
     * @param n
     * @param c
     */
    Dog(String n, String c) {
        /**
         * 在构造方法的实现里面首先使用super调用父类Animal的构造方法Animal(String name)。
         * 把子类对象里面的父类对象先造出来。
         */
        super(n);
        furColor = c;
    }

    /**
     * 子类Dog对从父类Animal继承下来的enjoy方法不满意,在这里重写了enjoy方法。
     */
    public void enjoy() {
        System.out.println("我养的狗高兴地叫了一声……");
    }
}

/**
 * 子类Bird从父类Animal继承下来,Bird类拥有Animal类所有的属性和方法
 * @author gacl
 *
 */
class Bird extends Animal {
    /**
     * 在子类Bird里面定义Bird类的构造方法
     */
    Bird() {
        /**
         * 在构造方法的实现里面首先使用super调用父类Animal的构造方法Animal(String name)。
         * 把子类对象里面的父类对象先造出来。
         */
        super("bird");
    }

    /**
     * 子类Bird对从父类Animal继承下来的enjoy方法不满意,在这里重写了enjoy方法。
     */
    public void enjoy() {
        System.out.println("我养的鸟高兴地叫了一声……");
    }
}

/**
 * 定义一个类Lady(女士)
 * @author gacl
 *
 */
class Lady {
    /**
     * 定义Lady类的私有成员变量name和pet
     */
    private String name;
    private Animal pet;

    /**
     * 在Lady类里面定义自己的构造方法Lady(),
     * 这个构造方法有两个参数,分别为String类型的name和Animal类型的pet,
     * 这里的第二个参数设置成Animal类型可以给我们的程序带来最大的灵活性,
     * 因为作为养宠物来说,可以养猫,养狗,养鸟,只要是你喜欢的都可以养,
     * 因此把它设置为父类对象的引用最为灵活。
     * 因为这个Animal类型的参数是父类对象的引用类型,因此当我们传参数的时候,
     * 可以把这个父类的子类对象传过去,即传Dog、Cat和Bird等都可以。
     * @param name
     * @param pet
     */
    Lady(String name, Animal pet) {
        this.name = name;
        this.pet = pet;
    }

    /**
     * 在Lady类里面自定义一个方法myPetEnjoy()
     * 方法体内是让Lady对象养的宠物自己调用自己的enjoy()方法发出自己的叫声。
     */
    public void myPetEnjoy() {
        pet.enjoy();
    }
}

public class Jerque {
    public static void main(String args[]) {
        /**
         * 在堆内存里面new了一只蓝猫对象出来,这个蓝猫对象里面包含有一个父类对象Animal。
         */
        Cat c = new Cat("Catname", "blue");
        /**
         * 在堆内存里面new了一只黑狗对象出来,这个黑狗对象里面包含有一个父类对象Animal。
         */
        Dog d = new Dog("Dogname", "black");
        /**
         * 在堆内存里面new了一只小鸟对象出来,这个小鸟对象里面包含有一个父类对象Animal。
         */
        Bird b = new Bird();

        /**
         * 在堆内存里面new出来3个小姑娘,名字分别是l1,l2,l3。
    * l1养了一只宠物是c(Cat),l2养了一只宠物是d(Dog),l3养了一只宠物是b(Bird)。
         * 注意:调用Lady类的构造方法时,传递过来的c,d,b是当成Animal来传递的,
         * 因此使用c,d,b这三个引用对象只能访问父类Animal里面的enjoy()方法。
         */
        Lady l1 = new Lady("l1", c);
        Lady l2 = new Lady("l2", d);
        Lady l3 = new Lady("l3", b);
        /**
         * 这三个小姑娘都调用myPetEnjoy()方法使自己养的宠物高兴地叫起来。
         */
        l1.myPetEnjoy();
        l2.myPetEnjoy();
        l3.myPetEnjoy();
    }
}

Dans l'exemple ci-dessus, nous avons constaté que si nous voulons ajouter un nouvel animal, il suffit de définir le La classe correspondante Inheriting Animal ne nécessite de toucher à aucun code, car l'élément central orienté objet - le polymorphisme - est utilisé ici. Différent de l'exemple précédent, bien que nous ayons toujours souligné que lors de l'utilisation d'une référence de classe parent pour pointer vers un objet de sous-classe, la classe parent ne peut pas accéder aux propres membres de la sous-classe, mais les méthodes sont différentes des membres de données. La méthode à appeler est déterminée. Quel que soit l'objet qui est nouveau, la méthode de l'objet correspondant est appelée. Cela dépend de l'objet nouveau réel, et non de la référence à l'objet. Par conséquent, lorsque différents types d'animaux sont transmis, mypetEnjoy() exécutera différentes méthodes.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer