• J2SE复习笔记


    equals方法
    OBJECT的equals方法定义为:x.equals(y)比较的是两个对象的在堆内存中的地址,相当于x==y,所以除非x和y是指向同一个对象的,否则都是返回FALSE;
    如果你想通过equals方法来比较2个对象的话,你可以自己重写OBJECT的equals方法,方法体你自己定义。比如String类自己就重写了equals方法,只要2
    个String对象x,y里面的内容相同,x.equals(y)就会返回TRUE;

    强制转换

    一个基类的引用类型变量可以指向其子类的对象;、
    一个基类的引用不可以访问其子类对象新增加的成员(属性和方法);
    可以使用引用变量instanceof类名来判断该引用型变量所指向的对象是否属于该类或该类的子类;

    父类引用指向子类对象的时候,它看到的只是作为父类引用的那部分所拥有的属性和方法,至于作为子类那部分的,对不起,没看到;

    class Animal{
           public String name = "Animal";
           public String age = "7";
           Animal(String name)
           {
            this.name =name;
           }
           
        }
        class Cat extends Animal{
           public String eyesColor;
           public String age = "3";
           Cat(String n,String c)
           {
            super(n);
            eyesColor =c;
           }
        }
        class Dog extends Animal{
            public String furColor;
            public String age = "4";
            Dog(String n,String c)
            {
              super(n);
              furColor=c;
            }
        }

        public class Test{
         public static void main(String args[])
          {
            Animal a= new Animal("name");
            Cat c =new Cat("catname","blue");
            Dog d = new Dog("dogname","black");

            System.out.println(a instanceof Animal);//true
            System.out.println(c instanceof Animal);//true
            System.out.println(d instanceof Animal);//true
            System.out.println(a instanceof Cat);//false
           
            a = new Dog("bigyellow","yellow");//a是父类Animal的引用,但是它指向的是子类Dog的对象;
            System.out.println(a.name);//bigyellow 因为会先调用到父类的构造函数给name赋值
            System.out.println(a.age);//7 用父类的属性
            System.out.println(c.age);//3 用子类的属性
          //  System.out.println(a.furColor);//!error 因为furColor是Dog自己的属性,不属于父类,所以父类引用指向子类对象的时候,它看到的只是作为父类引用的那部分所拥有的属性和方法,至于作为子类那部分的,对不起,没看到
            System.out.println(a instanceof Animal);//true
            System.out.println(a instanceof Dog);//true
            Dog d1 =(Dog)a;//要加强制转换符
            System.out.println(d1.furColor);//yellow
           }
        
          }
       
    多态
    多态的存在有3个必要条件:
    1:要有继承
    2:要有重写
    3:父类引用指向子类对象
    上面3个条件满足,当你调父类引用里面被重写的方法的时候,实际当中当中new的是哪个子类对象,就调用子类对象的方法

    class Animal{
      
    private String name;
      Animal (String name)
      {
       
    this.name =name;
      }
      
    public void enjoy{
      System.out.println(
    "叫声.......");
      }
    }

    class Cat extends Animal//条件1:子类继承父类
    {
      
    private String eyesColor;
      Cat(String n,String c)
      {
        
    super(n);
        eyesColor
    =c;
      }
      
    public void enjoy(){
      System.out.println(
    "猫叫声.......");
      }
    //条件2:子类重写了父类的enjoy()方法;
     
    }

    class Lady{
       
    private String name;
       
    private Animal pet;
       Lady(String name, Animal pet)
       {
        
    this.name =name;
        
    this.pet =pet;
       }
    }

    public class Test{
       
    public statc void main(String args[])
      {
        Cat c 
    =new Cat("catname","blue");
        Lady l1 
    =new Lady("l1",c);//条件3:父类引用指向子类对象,本来应该传递一个Animal的对象,传入的是它的子类Cat,所以根据
    多态性,这里应该实际当中当中new的是哪个子类对象,就调用子类对象的enjoy()方法
        l1.myPetEnjoy();
    //输出结果是:猫叫声.......
      }
       
    }
  • 相关阅读:
    .net remoting 易则易知,简则易从
    委托和匿名方法学习心得
    (4)插入排序之二 折半插入排序
    (2)排序概述
    (3)插入排序之一 直接插入排序
    (5)插入排序之三 2路插入排序
    (9)交换排序之二 快速排序
    (7)插入排序之五 希尔排序
    (6)插入排序之四 表插入排序
    (8)交换排序之一 起泡排序
  • 原文地址:https://www.cnblogs.com/tt_mc/p/1706475.html
Copyright © 2020-2023  润新知