由于前几个讲了面向对象的概念,这里插播几条以前总结的重要概念。
重载(overloading)
1) 方法重载是让类以统一的方式处理不同类型数据的一种手段。多个同名函数同时
存在,具有不同的参数个数/类型。重载Overloading是一个类中多态性的一种表现。
2) Java的方法重载,就是在类中可以创建多个方法,它们具有相同的名字,但具
有不同的参数和不同的定义。调用方法时通过传递给它们的不同参数个数和参数类型
来决定具体使用哪个方法, 这就是多态性。
3) 重载的时候,方法名要一样,但是参数类型和个数不一样,返回值类型可以相同
也可以不相同。无法以返回型别作为重载函数的区分标准。
Example:
- public class Dog {
- Dog() {
- this.bark();
- }
- void bark()//bark()方法是重载方法
- {
- System.out.println("no barking!");
- this.bark("female", 3.4);
- }
- void bark(String m, double l)//注意:重载的方法的返回值都是一样的,
- {
- System.out.println("a barking dog!");
- this.bark(5, "China");
- }
- void bark(int a, String n)//不能以返回值区分重载方法,而只能以“参数类型”和“类名”来区分
- {
- System.out.println("a howling dog");
- }
- public static void main(String[] args) {
- Dog dog = new Dog();
- }
- }
重写(Overriding)
1) 父类与子类之间的多态性,对父类的函数进行重新定义。如果在子类中定义某
方法与其父类有相同的名称和参数,我们说该方法被重写 (Overriding)。在Java中,
子类可继承父类中的方法,而不需要重新编写相同的方法。但有时子类并不想原封不
动地继承父类的方法,而是想作一定的修改,这就需要采用方法的重写。方法重写又
称方法覆盖。
2) 若子类中的方法与父类中的某一方法具有相同的方法名、返回类型和参数表,
则新方法将覆盖原有的方法。如需父类中原有的方法,可使用super关键字,该关键
字引用了当前类的父类。
3) 子类函数的访问修饰权限不能少于父类的;
下面是重写的例子:
Example:
- public class Base
- {
- void test(int i)
- {
- System.out.print(i);
- }
- void test(byte b)
- {
- System.out.print(b);
- }
- }
- public class TestOverriding extends Base
- {
- void test(int i)
- {
- i++;
- System.out.println(i);
- }
- public static void main(String[]agrs)
- {
- Base b=new TestOverriding();
- b.test(0);
- b.test((byte)0);
- }
- }
总结
方法的重写Overriding和重载Overloading是Java多态性的不同表现。重写 Overriding是父类与子类之间多态性的一种表现,重载Overloading是一个类中多态性的一种表现。如果在子类中定义某方法与其父类有相同的名称和参数,我们说该方法被重写 (Overriding)。子类的对象使用这个方法时,将调用子类中的定义,对它而言,父类中的定义如同被“屏蔽”了,而且如果子类的方法名和参数类型和个数都和父类相同,那么子类的返回值类型必须和父类的相同;如果在一个类中定义了多个同名的方法,它们或有不同的参数个数或有不同的参数类型,则称为方法的重载(Overloading)。Overloaded的方法是可以改变返回值的类型。也就是说,重载的返回值类型可以相同也可以不同。
抽象与继承
抽象概念
抽象就是忽略一个主题中与当前目标无关的那些方面,以便更充分地注意与当前目标有关的方面。抽象并不打算了解全部问题,而只是选择其中的一部分,暂时不用部分细节。抽象包括两个方面,一是过程抽象,二是数据抽象。
继承概念
继承是一种联结类的层次模型,并且允许和鼓励类的重用,它提供了一种明确表述共性的方法。对象的一个新类可以从现有的类中派生,这个过程称为类继承。新类继承了原始类的特性,新类称为原始类的派生类(子类),而原始类称为新类的基类(父类)。派生类可以从它的基类那里继承方法和实例变量,并且类可以修改或增加新的方法使之更适合特殊的需要。
Example:
- abstract class Door {//abstract class表示的是"is a"关系
- abstract void open();
- abstract void close();
- }
- interface Alarm {//interface表示的是"like a"关系
- void alarm();
- }
- class AlarmDoor extends Door implements Alarm {//继承关系
- void open() {
- System.out.println("open");
- }
- void close() {
- System.out.println("close");
- }
- public void alarm() {
- System.out.println("dididi");
- }
- }
最后讲下
面向接口编程最重要的价值在于隐藏实现,将抽象的实现细节封装起来而不对外开放,封装这对于Java EE 中的分层设计和框架设计尤其重要。但即便在编程时使用了接口,我们也需要将接口和实现对应起来,这就引出如何创建对象的问题。在创建型设计模式中,单例、工厂方法(模板方法)、抽象工厂等模式都是很好的解决办法。现在流行的控制反转(也叫依赖注入)模式是以声明的方式将抽象与实现连接起来,这既减少了单调的工厂类也更易于单元测试。