java提供四种访问控制修饰符号,用于控制方法和属性(成员变量)的访问权限(范围):
(1)公开级别:用 public 修饰,对外公开。
(2)受保护级别:用 protected 修饰,对子类和同一个包中的类公开。
(3)默认级别:没有修饰符号,向同一个包的类公开。
(4)私有级别:用private修饰,只有类本身可以访问,不对外公开。
(1)修饰符可以用来修饰类中的属性,成员方法以及类。
(2)只有默认的和public才能修饰类!并且遵循上述访问权限的特点。
(3)成员方法的访问规则和属性一致。
面向对象编程有三大特征:封装、继承、多态。
封装,是指隐藏对象的属性和实现细节,仅对外提供公共访问方式。
共性抽取,解决代码复用问题。
(1)子类继承了所有的属性和方法,非私有的属性和方法可以在子类直接访问,但是私有属性和方法不能在子类直接访问,要通过父类提供公共的方法去访问。
(2)子类必须调用父类的构造器, 完成父类的初始化。
(3)当创建子类对象时,不管使用子类的哪个构造器,默认情况下总会去调用父类的无参构造器,如果父类没有提供无参构造器,则必须在子类的构造器中用 super 去指定使用父类的哪个构造器完成对父类的初始化工作,否则,编译不会通过。
(4)如果希望指定去调用父类的某个构造器,则显式的调用一下 : super(参数列表)。
(5)super 在使用时,必须放在构造器第一行(super 只能在构造器中使用)。
(6)super() 和 this() 都只能放在构造器第一行,因此这两个方法不能共存在一个构造器。
(7)java 所有类都是 Object 类的子类,Object 是所有类的基类。
(8)父类构造器的调用不限于直接父类!将一直往上追溯直到 Object 类(顶级父类)。
(9)子类最多只能继承一个父类(指直接继承),即 java 中是单继承机制。
(10)不能滥用继承,子类和父类之间必须满足 is-a 的逻辑关系。
super 代表父类的引用,用于访问 父类 的属性、方法、构造器。
(1)子类的方法的形参列表、方法名称要和父类方法的形参列表、方法名称完全一样。
(2)子类方法的返回类型和父类方法返回类型一样,或者是父类返回类型的子类。
(3)子类方法不能缩小父类方法的访问权限。
“一种定义, 多种实现”。多态是建立在封装和继承基础之上的。
(1)方法的多态
重写和重载就体现多态
(2)对象的多态
1??一个对象的编译类型和运行类型可以不一致。
2??编译类型在定义对象时,就确定了,不能改变。
3??运行类型是可以变化的。
4??编译类型看定义时 = 号的左边,运行类型看 = 号的右边。
多态的向上转型:
(1)本质:父类的引用指向了子类的对象
(2)语法:父类类型 引用名 = new 子类类型():
(3)特点:编译类型看左边,运行类型看右边。
可以调用父类中的所有成员(需遵守访问权限),不能调用子类中特有成员,最终运行效果看子类的具体实现!
多态的向下转型:
(1)语法:子类类型 引用名 = (子类类型)父类引用;
(2)只能强转父类的引用,不能强转父类的对象。
(3)要求父类的引用必须指向的是当前目标类型的对象。
(4)当向下转型后,可以调用子类类型中所有的成员。
(1)当调用对象方法的时候,该 方法会和该对象的内存地址/运行类型 绑定。
(2)当调用对象属性时,没有动态绑定机制,哪里声明,哪里使用。
== 是一个比较运算符
(1)既可以判断基本类型,又可以判断引用类型。
(2)如果判断基本类型,判断的是值是否相等。
(3)如果判断引用类型,判断的是地址是否相等,即判定是不是同一个对象。
equals
(1)是 Object 类中的方法,只能判断引用类型。
(2)默认判断的是地址是否相等,子类中往往重写该方法,用于判断内容是否相等。
返回该对象的哈希码值。支持此方法是为了提高哈希表(例如 Hashtable 提供的哈希表)的性能。
(1)提高具有哈希结构的容器的效率!
(2)两个引用,如果指向的是同一个对象,则哈希值肯定是一样的!
(3)两个引用,如果指向的是不同对象,则哈希值是不一样的,小概率会碰撞。
(4)哈希值主要根据地址号来的! 不能完全将哈希值等价于地址。
默认返回:全类名+@+哈希值的十六进制。
子类往往重写 toString 方法,用于返回对象的属性信息。
public class Object {
public String toString() {
return getClass().getName() + "@" + Integer.toHexString(hashCode());
}
}
(1)当对象被回收时,系统自动调用该对象的 finalize 方法。子类可以重写该方法,做一些释放资源的操作。
(2)什么时候被回收:当某个对象没有任何引用时,则 jvm 就认为这个对象是一个垃圾对象,就会使用垃圾回收机制来销毁该对象,在销毁该对象前,会先调用 finalize 方法。
(3)垃圾回收机制的调用,是由系统来决定(即有自己的 GC 算法), 也可以通过 System.gc() 主动触发垃圾回收机制。