1、面向对象
面向对象(Object Oriented)的基本思想是使用对象、类、继承、封装、多态等基本概念来进行程序设计。从现实世界中客观存在的事物(即对象)出发来构造软件系统,并且在系统构造中尽可能运用人类的自然思维方式。
2、对象
对象是系统中用来描述客观事物的一个实体,它是构成系统的一个基本单位。一个对象由一组属性和对这组属性进行操作的方法的这一组服务组成。
类的实例化可生成一个对象,一个对象的生命周期包括三个阶段:生成、使用、消除。
当不存在对一个对象的引用时,该对象成为一个无用对象。Java的垃圾收集器自动扫描对象的动态内存区,把没有引用的对象作为垃圾收集起来并释放。当系统内存用尽或调用System.gc()要求垃圾回收的时候,垃圾回收线程与系统同步运行。
3、类
类是具有相同属性和方法的一组对象的集合,它为属于该类的所有对象提供了统一的抽象描述,其内部包括属性和方法两个主要部分。在面向对象的编程语言中,类是一个独立的程序单元,它应该有一个类名并包括属性和方法两个主要部分。
Java中的类实现包括两个部分:类声明和类体。
类声明
[ public ][ abstract | final ] class className [extends superclassNmae] [implements interfaceNameList]{...}
其中,修饰符public,abstract,final 说明了类的属性,className为类名,superclassName为类的父类的名字,interfaceNameList为类所实现的接口列表。
类体
class className{
//成员变量
[ public | protected | private ] [ static ] [ final ] [ transient ] [ volatile ] type variableName;
//成员方法
[ public | protected | private ] [ static ] [ final | abstract ] [ native ] [ synchronized ] returnType methodName ([paramList]) [ throws exceptionList]{
statements
}
}
成员变量限定词的含义:
- static:静态变量(类变量)
- final:常量
- transient:暂时性变量,用于对象的存档,用于对象的串行化
- volatile:贡献变量,用于并发线程的共享方法的实现也包括两部分:方法声明和方法体。
方法声明
方法声明中的限定词的含义:
- static:类方法,可通过类名直接调用
- abstract:抽象方法,没有方法体
- final:方法不能被重写
- native:集成其他语言的方法
- synchronized:控制多个并发线程的访问
方法的声明包括方法名、返回类型和外部参数。其中参数的类型可以是基本数据类型,也可以是引用数据类型。
对于基本数据类型来说,Java实现的是值得传递,方法接收参数的值,但不能改变参数的值。如果要改变参数的值,则用引用数据类型,因为引用数据类型传递给方法的数据是内存的地址,方法中对数据的操作(即改变地址)可以改变数据的值(即地址会指向不同的实例)。
方法体
方法体是对方法的实现,它包括局部变量的声明以及所有合法的Java指令。方法体中声明的局部变量的作用域在该方法的内部。若局部变量与类的成员变量同名,则类的成员变量被隐藏。
为了区别参数和类的成员变量,我们必须使用this。this用在一个方法中引用当前对象,它的值是调用该方法所在的对象。返回值须与返回类型一致,或者完全相同,或者是其子类。当返回类型是接口时,返回值必须实现接口。
构造方法
- 构造方法是一个特殊的方法。Java中的每一个类都有构造方法,用来初始化该类的一个对象。
- 构造方法具有和类同样的名称,而且不返回任何的数据类型。
- 重载经常用于构造方法。
- 构造方法只能由new运算符调用。
4、面向对象的基本特征
封装
封装性就是尽可能的隐藏对象内部的细节,对外形成一道边界,只保留有限的接口和方法与外界进行交互。封装的原则是使对象以外的部分不能随意的访问和操作对象的内部属性,从而避免了外界对对象内部属性的破坏。
可以通过对类的成员设置一定的访问权限,实现类中成员的信息隐蔽。
private:类中限定为private的成员,只能被这个类的本身访问。如果一个类的构造方法声明为private,则其他类不能生成该类的一个实例。
default:类中不加任何的访问权限限定成员属于缺省的(default)访问状态,可以被这个类的本身和同一个包里的类所访问。
protected:类中限定为protected的成员,可以被这个类的本身、它的子类(包括同一个包中以及不同包中的子类)和同一个包中的所有其他的类访问。
public:类中限定为public的成员,可以被所有的类访问。
下图“*”表示可以访问:
private | default | protected | public | |
---|---|---|---|---|
同一类中 | * | * | * | * |
同一包中 | * | * | * | |
子类 | * | * | ||
全局范围 | * |
继承
子类的对象拥有父类的全部属性与方法,称作子类对父类的继承。
Java中父类可以拥有多个子类,但是子类只能继承一个父类,称为单继承。
继承实现了代码的复用。
Java中所有类都是通过直接或者间接地继承了java.lang.Object类得到的。换言之Object是Java中所有类的父类或者超类。
子类不能继承父类中访问权限是private的成员变量和成员方法。
子类可以重写父类的方法,以及命名与父类同名的成员变量。
Java中通过super来实现对父类成员的访问,super用来引用当前对象的父类。super的使用有三种情况:
访问父类被隐藏的成员变量,如:super.variable;
调用父类中被重写的方法,如:super.Method([paramlist]);。
调用父类的构造方法,如:super([paramlist]);。
多态
对象的多态性是指在父类定义的属性或者方法被子类继承之后,可以具有不同的数据类型或表现出不同行为。这使得同一个属性或者方法在父类及其各个子类中具有不同的语义。例如:“几何图形”的“绘图”方法,“椭圆”和“多边形”都是“几何图形”的子类,其“绘图”的方法不一样。
Java的多态性体现在两个方面:由方法重载实现的静态多态性(编译时多态)和方法重写实现的动态多态性(运行时多态)。
编译时多态:在编译阶段,具体调用哪个被重载的方法,编译器会根据参数的不同静态(参数的类型、参数的顺序、参数的个数)确定其相应的方法。(比如在构造方法和一般方法里面);子类重写父类的方法。
运行时多态:由于子类继承了父类的所有的属性(私有属性除外),所有的子类对象可以作为父类对象使用。程序中凡是使用父类对象的地方,都可以用子类对象来代替。一个对象可以通过引用子类的实例来调用子类的方法。(比如Dog类和Cat类是Animal的子类,我们定义一个方法void letSleep(Animal animal){animal.sleep();},然后sleep这个父类中的方法,分别被子类重写。那么我们向letSleep这个方法分别传入dog(Dog类的实例)或者cat(Cat类的实例),那么该方法就会分别调用dog中的sleep()方法和cat中的sleep()方法)。
重载 (overload)
方法重载是让类以统一的方式处理不同数据类型的手段。
一个类中可以创建多个方法,它们具有相同的名字,但具有不同的参数和不同的定义。调用方法时通过传递给它们的不同参数个数和参数类型来决定具体使用哪个方法。
返回值类型可以相同也可以不同,无法以返回值类型作为重载方法的区分标准。
重写 (override)
子类对父类的方法进行重新编写。如果在子类中的方法与其父类有相同的方法名、返回类型和参数表,我们说该方法被重写。
如需父类中原有的方法,可使用super关键字,该关键字引用了当前类的父类。
子类函数的访问修饰权限不能低于父类的。