1.封装性,多态性,继承性
其实就是,把该隐藏的隐藏起来,把该暴露的暴露出来,
就像是操作洗衣机,你并不需要知道洗衣机的内部结构,也完全没必要知道洗衣机器的内部结构,这个对你完全没有用处。
就像操作汽车,你也没必要知道汽车的内部结构,这种东西完全没有任何用处。
面向对象和面向过程的一些特性。
封装特性需要通过修饰符来进行体现。
public / protected/default(什么也不写就是default)/private
关于面向对象中继承性
1.提高了代码复用性
2.减少了代码冗余
3.多态的前提也是继承。
super.方法,主要是特别是强调,父类中被重写的方法,这里被调用。
super使用构造器得问题,
super也会调用父类的构造器,
子类会默认使用父类的构造器,默认使用。
super必须放在子类构造器首行,表示使用父类构造器首行。
子类构造器如果不写情况下,默认使用父类构造器的无参数构造,有一个super()送给你,默认使用父类空参构造器。
可以在子类构造器中用super(),super(name,age)去使用父类构造器,记得将super放在子类构造器首行。
子类对象实例化全过程,
子类继承父类时候,继承了父类声明的属性和方法,创建子类对象,在堆空间中就会加载父类所有方法和属性,我们一定会直接或者间接调用父类构造器,才能加父类全部属性和方法。
子类的构造函数(有参或无参),都将调用父类的无参构造函数。
子类一定会调用父类构造函数的。
父类和子类加载进内存过程:
1.父类和子类静态加载进内存
2.父类属性和方法加载进内存然后执行父类构造方法,加载完成属性后,再进行构造,构造完父类之后再加载子类属性和方法,然后执行子类构造。
子类 调用 父类的构造函数:(构造函数不会被继承,只是被子类调用而已)
1、子类所有的 构造函数 默认调用父类的无参构造函数(其实是默认省略掉了一行代码:super(););省略掉的这行super()代码可以自行添加到构造函数的第一行(必须是第一行,否则报错)
2、如果父类没有定义构造函数,系统会默认定义一个无参无返回值的构造函数,子类继承时无需(无需的意思是:可以写可以不写)在子类构造函数中显式调用super( );如果父类定义了构造函数,系统不会再默认定义任何 无参无返回值 的构造函数,此时子类的构造函数中必须显式调用super( [arg0][,arg1]…),即,显式调用对应的参数个数、对应参数类型与此super( [arg0][,arg1]… )的父类构造函数。
3、如果子类的某个构造函数 想 调用父类的其他的带参数的构造函数,在构造函数的第一行人为添加 super(val1,val2[,val3…]),super()括号中的变量数量由想调用的父类的构造函数中的变量数量决定。如代码中的line 2,调用的是父类构造函数中两个参数的构造函数,那么Super(20,“Hello”)就两个变量。
4、自行添加super(val1,val2,…),就可以指定调用父类的那个参数类型和数量一致的构造函数。之后在此子类构造函数中,系统不会再默认调用父类无参构造函数;
5、如果子类的每个构造函数都自行添加super([val1,]…),除非人为调用父类无参构造函数,否则的话父类的无参构造函数可以不写。有super指定调用的父类构造函数存在即可
2017-7-25追加
6、super指代 父类对象 可以在子类中使用 super.父类方法名();调用父类中的方法(无论是类方法还是实例方法都可以,除此调用实例方法的还可以在方法内部实例化再调用)
**
总之:存在继承关系的子类初始化,必须先调用父类构造器,你自己不显式调用,Java就强制默认让你调用父类无惨构造方法