Java三大特性
封装性(高内聚,低耦合)
意义:
- 提高代码安全性,保护数据
- 隐藏代码的实现细节
- 统一接口
- 增加系统的可维护性
继承性
super注意点:
super调用父类的构造方法,必须在构造方法的第一个
super 必须只能出现在子类的方法或者构造方法中!
super和 this 不能同时调用构造方法!
Vs this:
代表的对象不同:
this:本身调用者这个对象
super:
代表父类对象的应用
前提
this:没有继承也可以使用
super:只能在继承条件才可以使用
构造方法
this() :本类的构造
super():父类的构造!
重写:需要有维承关系,子类重写父类的方法!
1.方法名必须相同
2.参数列表列表必须相同
3.修饰符:范围可以扩大但不能缩小:
public>Protected>default>private
4.抛出的异常:范围, 可以被缩小,但不能扩大: ClassNotFoundException --> Exception(大)
重写,子类的方法和父类必要致:方法体不同!
为什么需要重写:
1.父类的功能,子类不一定需要, 或者不-定满足!
Alt + Insert ;override;
多态性
public class Person {
public void run(){
System.out.println("person run");
}
}
public class Student extends Person{
@Override
public void run() {
System.out.println("son student run");
}
public void eat(){
System.out.println("student eat");
}
}
public class Application {
public static void main(String[] args) {
//一个对象的实际类型是确定的
//可以指向的引用类型就不确定了:父类的引用指向子类
Student s1 = new Student();
Person s2 = new Student();
Object s3=new Student();
s2.run();//子类重写了父类的方法,执行子类的方法(只要子类重写了父类的方法就执行子类的方法,否则才执行父类的方法)
s1.run();
//运行结果分别是 son student run
// son student run
多态的注意事项:
1.多态是方法的多态,属性没有多态
2.父类和子类,有联系,类型转换异常
3.存在条件:继承关系,方法需重写,父类指向子类对象 Father f1=new Son();只要子类重写了父类的方法就执行子类的方法,否则才执行父类的方法
什么情况下没有多态?
1.static 方法,属于类,它不属于实例
2.final 常量
3.private 方法
- 父类引用指向子类的对象
- 把子类转换为父类,向上转型
- 把父类转换为子类,向下转型,需要强制转换,但是转换后会丢失子类一些特有的方法
- 方便方法的调用,减少重复的代码,简洁
Serializable接口是启用其序列化功能的接口。实现java.io.Serializable 接口的类是可序列化的。没有实现此接口的类将不能使它们的任意状态被序列化或逆序列化。
这个介绍非常的不接地气,于是我与去看了几篇博客,有一个小姐姐的博客引起了我的注意,她是这样理解的:
序列化的过程,就是一个“freeze”的过程,它将一个对象freeze(冷冻)住,然后进行存储,等到再次需要的时候,再将这个对象de-freeze就可以立即使用。
我们以为的没有进行序列化,其实是在声明的各个不同变量的时候,由具体的数据类型帮助我们实现了序列化操作。
序列化的过程,就是一个“freeze”的过程,它将一个对象freeze(冷冻)住,然后进行存储,等到再次需要的时候,再将这个对象de-freeze就可以立即使用。
我们以为的没有进行序列化,其实是在声明的各个不同变量的时候,由具体的数据类型帮助我们实现了序列化操作。
存储对象在存储介质中,以便在下次使用的时候,可以很快捷的重建一个副本,便于数据传输,尤其是在远程调用的时候!
其实说了这么多,想表达的意思就是:
Serializable接口是一个里面什么都没有的接口
它的源代码是public interface Serializable{},即什么都没有。
如果一个接口里面什么内容都没有,那么这个接口是一个标识接口,比如,一个学生遇到一个问题,排错排了几天也没解决,此时,她举手了(示意我去帮他解决),然后我过去,帮他解决了,那么这个举手其实就是一个标识,自己不能解决的问题标示我去帮他解决,在Java中的这个Serializable接口是给JVM看的,告诉JVM,我不做这个类的序列化了,你(JVM)给我序列化,序列化就是变成二进制流,比如云计算、Hadoop,特别是Hadoop完全就是分布式环境,那么就要涉及到对象要在网络中传输,里面的全是二进制流,当然你来做这个序列化操作也可以,但是这个类里面可能还有一个类,如果你把外面的类对象Person变成二进制,那么里面也要序列化(这要用到深度遍历,很麻烦),干脆告诉JVM,让他来帮你做。
serializable接口就是Java提供用来进行高效率的异地共享实例对象的机制,实现这个接口即可。