2.面向对象基础知识

  1. 构造方法的名称就是类名,构造方法没有返回值(也没有void),
    在子类构造方法当中,对于无参构造方法会默认包含一个super(),调用父类的无参构造方法。
    2.可以定义多个构造方法,在通过new操作符调用的时候,编译器通过构造方法的参数数量、位置和类型自动区分
    3.一个构造方法可以调用其他构造方法,这样做的目的是便于代码复用。调用其他构造方法的语法是this(构造参数),

注意:对'this()'的调用必须是构造函数体中的第一个语句;

  1. JAVA 中创建子类对象时 需要调用先父类的构造函数, 如果子类的构造方法中定义了需要调用的父类构造函数,则调用所指定的函数,如果子类构造方法中没有制定调用父类的构造方法 ,则调用父类的无参构造方法。 但是如果父类中定义了有参的构造方法,并且没有定义无参构造方法。编译就会报错!!
    调用构造方法

4.重载和重写
重载:方法名相同,但各自的参数不同,返回类型可以相同也可以不同。但通常方法重载的返回值类型通常都是相同的。
重写(Override): 在继承关系中,子类如果定义了一个与父类方法签名完全相同的方法,

子类的返回值必须【小于等于】父类的返回范围
子类的权限修饰符必须【大于等于】父类的权限,
public > protected > 省略不写 > private

方法签名包括方法参数列表和方法名,不包括返回类型,更加不包括访问修饰符和异常类型
5.继承:使用extend,Java只允许单继承,所有类最终的根类是Object;
>继承有个特点,就是子类无法访问父类的private字段或者private方法;
为了让子类可以访问父类的字段,我们需要把private改为protected。用protected修饰的字段可以被子类访问;
在Java中,任何class的构造方法,第一行语句必须是调用父类的构造方法。
如果没有明确地调用父类的构造方法,编译器会帮我们自动加一句super()

  1. 一个子类类型安全地变为父类类型的赋值,被称为向上转型(upcasting).
    向上转型实际上是把一个子类型安全地变为更加抽象的父类型:
Student s = new Student();
Person p = s; // upcasting, ok
Object o1 = p; // upcasting, ok
Object o2 = s; // upcasting, ok

7.把一个父类类型强制转型为子类类型,就是向下转型(downcasting),最好借助instanceof判断;

8.instanceof实际上判断一个变量所指向的实例是否是指定类型,或者这个类型的子类。
如果一个引用变量为null,那么对任何instanceof的判断都为false。
10.多态是指,针对某个类型的方法调用,其真正执行的方法取决于运行时期实际类型的方法;
Java的实例方法调用是基于运行时的实际类型的动态调用,而非变量的声明类型。
下面例子:实际运行的Students的run()方法,而非Person

  Student s = new Student("Xiao Ming", 12, 89);
        Person p = s;
        s.run();//Student.run

11,final关键字:
可以用来修饰 类、方法、成员变量、局部变量;

用final修饰的方法不能被Override,如果一个父类不允许子类对它的某个方法进行覆写,可以把该方法标记为final;
用final修饰的不能被继承;如果一个类不希望任何其他类继承自它,那么可以把这个类本身标记为final;
用final修饰的局部变量在初始化后不能被修改;对final字段重新赋值会报错:
用final修饰的成员变量:由于成员变量有默认值,所以必须要主动赋值,赋值的方式有两种:a、直接赋值;b、通过构造方法赋值,必须保证所有的构造方法对final变量都赋值

image.png

对于类和方法来说,关键字 abstract 和 final 是不能同时使用的,自相矛盾

12,抽象类abstract:

abstract class Person {
    public abstract void run();
    public abstract String getName();

    private String name; //抽象   可以定义实例字段
    public void teach(){ //抽象   可以定义非抽象方法
        System.out.println("我会教书");
    }
}

通过abstract定义的方法是抽象方法,它只有定义,没有实现。抽象方法定义了子类必须实现的接口规范;
定义了抽象方法的class必须被定义为抽象类,从抽象类继承的子类必须实现抽象方法;
只有覆盖了抽象类中所有的抽象方法后,其子类才可以创建对象。否则该子类还是一个抽象类
抽象类不可以直接创建对象
抽象类中,可以有构造方法,但只能通过实现类调用

  1. 接口interface
interface Person {
    void run();
    String getName();
}

所谓interface,就是比抽象类还要抽象的纯抽象接口,因为它连字段都不能有
因为接口定义的所有方法默认都是public abstract的
当一个具体的class去实现一个interface时,需要使用implements关键字
一个类只能继承自另一个类,不能从多个类继承。但是,一个类可以实现多个interface
interface是可以有静态字段的,并且静态字段必须为final类型:例如:public static final int MALE = 1;
因为interface的字段只能是public static final类型,所以我们可以把这些修饰符都去掉,可以简写为:int MALE = 1;


接口总结
  1. 静态方法和静态变量:

静态字段属于所有实例“共享”的字段,实际上是属于class的字段;
调用静态方法不需要实例,无法访问this,但可以访问静态字段和其他静态方法;
静态方法常用于工具类和辅助方法。
静态不能直接访问非静态,因为java内存中是现有的 静态内容后有的 非静态内容;
静态中 不能用this

  1. public、protected、private这些修饰符。在Java中,这些修饰符可以用来限定访问作用域

定义为public的class、interface可以被其他任何类访问
定义为public的field、method可以被其他类访问
定义为private的field、method无法被其他类访问
【推荐把private方法放到后面,因为public方法定义了类对外提供的功能,阅读代码的时候,应该先关注public方法】
protected作用于继承关系。定义为protected的字段和方法可以被子类访问,以及子类的子类

16.一个.java文件只能包含一个public类,但可以包含多个非public类。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。