java的implements怎么用_Java 中extends与implements使用方法

[                              使用JSON的方法   JSON 即 JavaScript Object Natation,它是一种轻量级的数据交换格式,非常适合于服务器与 JavaScript 的交互。本文将快

初学Java语言, 代码中的extends和implements让我感到很迷惑,现在终于弄明白它们之间的区别和用法了。

//定义一个Runner接口 public inerface Runner { int ID = 1; void run (); }

//定义一个interface Animal,它继承于父类Runner interface Animal extends Runner { void breathe (); }

//定义Fish类,它实现了Animal接口的方法run()和breather() class Fish implements Animal { public void run () //实现了Animal方法run() { System.out.println("fish is swimming"); } public void breather() { System.out.println("fish is bubbing"); } } //定义了一个抽象类LandAnimal,它实现了接口Animal的方法。 abstract LandAnimal implements Animal { public void breather () { System.out.println("LandAnimal is breathing"); } } //定义了一个类Student,它继承了类Person,并实现了Runner接口的方法run()。 class Student extends Person implements Runner { ...... public void run () { System.out.println("the student is running"); } ...... } //定义了一个接口Flyer interface Flyer { void fly (); } //定义了一个类Bird,它实现了Runner和Flyer这两个接口定义的方法。 class Bird implements Runner , Flyer { public void run () //Runner接口定义的方法。 { System.out.println("the bird is running"); } public void fly () //Flyer接口定义的方法。 { System.out.println("the bird is flying"); } } //TestFish类 class TestFish { public static void main (String args[]) { Fish f = new Fish(); int j = 0; j = Runner.ID; j = f.ID; } }

接口实现的注意点:

a)实现一个接口就是要实现该接口的所有的方法(抽象类除外)。

b)接口中的方法都是抽象的。

c)多个无关的类可以实现同一个接口,一个类可以实现多个无关的接口。

extends与implements的区别:

extends 是继承父类,只要那个类不是声明为final或者那个类定义为abstract的就能继承,JAVA中不支持多重继承,但是可以用接口来实现,这样就用到了implements,继承只能继承一个类,但implements可以实现多个接口,用逗号分开就行了。

比如:

class A extends B implements C,D,E {}    (class 子类名 extends 父类名 implenments 接口名)

[在标准Java库中包含150多个equals方法的实现,这里给出一个比较完美的实现方法。1)显示参数命名为otherObject,稍后需要将它转换成另一个叫做other的变量。2)检测this与

父类与子类继承关系上的不同:

A a = new B(); 结果a是一个A类的实例,只能访问A中的方法,那么又和A a = new A();有什么区别呢?

***********************************************************************************************

class B extends A

继承过后通常会定义一些父类没有的成员或者方法。

A a = new B();

这样是可以的,上传。

a是一个父类对象的实例,因而不能访问子类定义的新成员或方法。

***********************************************************************************************

假如这样定义:

class A

{

int i;

void f(){}

}

class B extends A

{

int j;

void f(){}       //重写

void g(){}

}

然后:

B b = new B();

b就是子类对象的实例,不仅能够访问自己的属性和方法,也能够访问父类的属性和方法。诸如b.i,b.j,b.f(),b.g()都是合法的。此时b.f()是访问的B中的f()

A a = new B();

a虽然是用的B的构造函数,但经过upcast,成为父类对象的实例,不能访问子类的属性和方法。a.i,a.f()是合法的,而a.j,a.g()非法。此时访问a.f()是访问B中的f()

***********************************************************************************************

A a = new B(); 这条语句,实际上有三个过程:

(1) A a;

将a声明为父类对象,只是一个引用,未分配空间

(2) B temp = new B();

通过B类的构造函数建立了一个B类对象的实例,也就是初始化

(3) a = (A)temp;

将子类对象temp转换未父类对象并赋给a,这就是上传(upcast),是安全的。

经过以上3个过程,a就彻底成为了一个A类的实例。

子类往往比父类有更多的属性和方法,上传只是舍弃,是安全的;而下传(downcast)有时会增加,通常是不安全的。

***********************************************************************************************

a.f()对应的应该是B类的方法f()

调用构造函数建立实例过后,对应方法的入口已经确定了。

如此以来,a虽被上传为A类,但其中重写的方法f()仍然是B的方法f()。也就是说,每个对象知道自己应该调用哪个方法。

A a1 = new B();

A a2 = new C();

a1,a2两个虽然都是A类对象,但各自的f()不同。这正是多态性的体现。

***********************************************************************************************[   什么时候用assert.断言是一个包含布尔表达式的语句,在执行这个语句时假定该表达式为 true.如果表达式计算为 false,那么系统会报告一个 AssertionError.它用于调试目

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值