每日一学之Java基本特征
个人学习记录,有误可以指出,长期更新
1、封装(encapsulation)
1.1什么是封装
封装是一个比较广泛的概念,小到封装属性,大到封装框架与项目。封装就是隐藏对象的属性及方法,对外留下可以调用
封装内容的方法作为接口。封装后我们要用公有(public)的方法来访问或修改被封装的属性(通常用private修饰)。
1.2封装的优劣
封装的好处:让程序内部结构更安全;封装重复部分代码,有需要方便随时调用,也就是安全性与易用性。
1.3相关知识:访问修饰符
修饰符 | 所在类 | 所在包 | 子类 | 包外(其他包) |
---|---|---|---|---|
public | 允许 | 允许 | 允许 | 允许 |
protected | 允许 | 允许 | 允许 | |
不写(default) | 允许 | 允许 | ||
private | 允许 |
1.类指外部类,也叫顶级类,修饰符只有public(表示该类可在项目所以类中被导入)default(该类只在同一个包中使
用)abstract与final,用abstract修饰的类为没有具体对象的抽象类。
2.内部类是在类的内部但不包括位于构造器、方法内,且有名称的类,修饰符包括public,private,protected(只能用
于内部类而不能修饰类)。
3.局部内部类(最终类)是位于构造器、方法内的有名称类,最多用final修饰,用final修饰的类通常有固定作用,用来
完成某种标准功能。
扩展
static与final的区别:
1、static静态修饰关键字,修饰变量、程序块、类方法:当定义一个static变量时,jvm会将其分配在内存堆上,所有程序对它的引用都指向此地址而不会重新分配内存;当定义static代码块,jvm会优先加载这部分代码在系统初始化的时候;当定义static类方法后,可以直接通过类来调用方法而不用创建对象。
注:static变量叫静态变量或类变量,没被其修饰的叫实例变量,实例变量的每次创建都会分配新内存。
2、final可以修饰方法、变量、类:定义变量时jvm会将其分配到常量池中,其值不可改;当修饰方法时,该方法在子类中无法重写;定义类时不可继承。
2、继承(extends or implements)
2.1什么是继承
继承(inheritance)就是让某个类型的对象获得另一个类型的对象的属性的方法。继承是子类继承父类的特征和行为,使得子类对象(实例)具有父类的实例域和方法,或子类从父类继承方法,使得子类具有父类相同的行为。
2.2为什么要继承
继承可以复用以前的代码,缩短开发周期。
2.3继承的特点
单继承:一个子类只有一个对应父类(多继承Java不支持,但可以实现,三种方式:内部类、多层继承、实现接口)。
this与super关键字:this表示当前对象,super表示父类对象。父类构造方法无法被继承,因为构造方法与类同名继承
不改变方法名会造成语法冲突,所以子类不能继承只能调用。
子类的构造过程必须调用其父类的构造方法:Java虚拟机构造子类对象前会先构造父类对象,父类对象构造完成之后再
来构造子类特有的属性,这被称为内存叠加。而Java虚拟机构造父类对象会执行父类的构造方法,所以子类构造方法必须调
用super()即父类的构造方法,通常我们写继承时子类没写super()调用这时系统默认在执行时添加了父类的无参构造方式。
在Java继承中,父子类初始化先后顺序为:父类中静态成员变量和静态代码块、子类中静态成员变量和静态代码块、父
类中普通成员变量和代码块,父类的构造函数、子类中普通成员变量和代码块,子类的构造函数。
扩展
重写(override):方法重写是子类出现和父类一样的方法(返回值类型,方法名,参数列表都相同),它基于继承基础上,外壳不变,内容重写。重写只存在于子类父类之前,同类中只能重载。不能降低方法访问权限,访问修饰符作用域不能比父类小。
重载(overload):方法名相同,参数不一致(必须不一致),返回值类型可以改变,访问修饰符可以改变。
Object类:所有类的根类,所有类都隐式继承自object类,构造方法唯一(无参构造)。常用方法toString()、equals()。
3、多态(Polymorphism)
3.1存在条件
继承、子类中存在父类重写方法、父类引用变量指向子类对象实例(向上转型)。
3.2多态的三种形式
普通类多态定义
class Fu{}
class Zi extends Fu{}
Fu f = new Zi();
抽象类多态定义
abstract class Fu{
public abstract void Fangfa();
}
class Zi extends Fu{
public void Fangfa(){
System.out.println(“重写父类抽象方法”);
}
}
Fu f = new Zi();
接口多态定义
interface Fu{
public abstract void Fangfa();
}
class Zi implements Fu{
public void Fangfa(){
System.out.println(“重写接口抽象方法”);
}
}
Fu f = new Zi();
别人总结多态的一句话:编译看父类,运行看子类。
当子类重写父类的方法被调用时,只有对象继承链中的最末端的方法才会被调用。
3.3多态:方法的动态绑定
在运行时根据具体对象的类型进行绑定除了由private、final、static 所修饰的方法和构造方法外,JVM在运行期间决定
方法由哪个对象调用的过程称为动态绑定。动态绑定的过程:虚拟机提取对象的实际类型的方法表;虚拟机搜索方法签名;调
用方法。
注:静态绑定与动态绑定的区别:
静态绑定:编译时期触发:提前知道错误,提高运行效率。
动态绑定:运行时,提高代码可用性,更灵活,同时多态是设计模式的基础,可以降低耦合性。