java接口例子

“interface”(接口)关键字使抽象的概念更深入了一层。我们可将其想象为一个“纯”抽象类。它允许创建者规定一个类的基本形式:方法名、自变量列表以及返回类型,但不规定方法主体。接口也包含了基本数据类型的数据成员,但它们都默认为static和final。接口只提供一种形式,并不提供实施的细节。
接口这样描述自己:“对于实现我的所有类,看起来都应该象我现在这个样子”。因此,采用了一个特定接口的所有代码都知道对于那个接口可能会调用什么方法。这便是接口的全部含义。所以我们常把接口用于建立类和类之间的一个“协议”。有些面向对象的程序设计语言采用了一个名为“protocol”(协议)的关键字,它做的便是与接口相同的事情。
为创建一个接口,请使用interface关键字,而不要用class。与类相似,我们可在interface关键字的前面增加一个public关键字(但只有接口定义于同名的一个文件内);或者将其省略,营造一种“友好的”状态。
为了生成与一个特定的接口(或一组接口)相符的类,要使用implements(实现)关键字。我们要表达的意思是“接口看起来就象那个样子,这儿是它具体的工作细节”。除这些之外,我们其他的工作都与继承极为相似。下面是乐器例子的示意图:

具体实现了一个接口以后,就获得了一个普通的类,可用标准方式对其进行扩展。
可决定将一个接口中的方法声明明确定义为“public”。但即便不明确定义,它们也会默认为public。所以在实现一个接口的时候,来自接口的方法必须定义成public。否则的话,它们会默认为“友好的”,而且会限制我们在继承过程中对一个方法的访问——Java编译器不允许我们那样做。
在Instrument例子的修改版本中,大家可明确地看出这一点。注意接口中的每个方法都严格地是一个声明,它是编译器唯一允许的。除此以外,Instrument5中没有一个方法被声明为public,但它们都会自动获得public属性。如下所示:

  1. //: Music5.java
  2. // Interfaces
  3. import java.util.*;
  4. interface Instrument5 {
  5.   // Compile-time constant:
  6.   int i = 5// static & final
  7.   // Cannot have method definitions:
  8.   void play(); // Automatically public
  9.   String what();
  10.   void adjust();
  11. }
  12. class Wind5 implements Instrument5 {
  13.   public void play() {
  14.     System.out.println("Wind5.play()");
  15.   }
  16.   public String what() { return "Wind5"; }
  17.   public void adjust() {}
  18. }
  19. class Percussion5 implements Instrument5 {
  20.   public void play() {
  21.     System.out.println("Percussion5.play()");
  22.   }
  23.   public String what() { return "Percussion5"; }
  24.   public void adjust() {}
  25. }
  26. class Stringed5 implements Instrument5 {
  27.   public void play() {
  28.     System.out.println("Stringed5.play()");
  29.   }
  30.   public String what() { return "Stringed5"; }
  31.   public void adjust() {}
  32. }
  33. class Brass5 extends Wind5 {
  34.   public void play() {
  35.     System.out.println("Brass5.play()");
  36.   }
  37.   public void adjust() { 
  38.     System.out.println("Brass5.adjust()");
  39.   }
  40. }
  41. class Woodwind5 extends Wind5 {
  42.   public void play() {
  43.     System.out.println("Woodwind5.play()");
  44.   }
  45.   public String what() { return "Woodwind5"; }
  46. }
  47. public class Music5 {
  48.   // Doesn't care about type, so new types
  49.   // added to the system still work right:
  50.   static void tune(Instrument5 i) {
  51.     // ...
  52.     i.play();
  53.   }
  54.   static void tuneAll(Instrument5[] e) {
  55.     for(int i = 0; i < e.length; i++)
  56.       tune(e[i]);
  57.   }
  58.   public static void main(String[] args) {
  59.     Instrument5[] orchestra = new Instrument5[5];
  60.     int i = 0;
  61.     // Upcasting during addition to the array:
  62.     orchestra[i++] = new Wind5();
  63.     orchestra[i++] = new Percussion5();
  64.     orchestra[i++] = new Stringed5();
  65.     orchestra[i++] = new Brass5();
  66.     orchestra[i++] = new Woodwind5();
  67.     tuneAll(orchestra);
  68.   }
  69. ///:~

代码剩余的部分按相同的方式工作。我们可以自由决定上溯造型到一个名为Instrument5的“普通”类,一个名为Instrument5的“抽象”类,或者一个名为Instrument5的“接口”。所有行为都是相同的。事实上,我们在tune()方法中可以发现没有任何证据显示Instrument5到底是个“普通”类、“抽象”类还是一个“接口”。这是做是故意的:每种方法都使程序员能对对象的创建与使用进行不同的控制。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值