Java中的接口怎么实现?

Python011

Java中的接口怎么实现?,第1张

举个面积的例子:在java中,定义一个接口,声明计算长方形面积和周长的抽象方法,再用一个类去实现这个接口,再编写一个测试类去使用这个接口。首先,接口必须单独存放,如果我们用eclipse编程的话,它们提示:The public type **** must be defined in its own file,意思是必须要定义在其自己的文件中,所以要为接口文件单独存放起来,举例,我们的接口要实现获到矩形的长,宽,面积,周长,所以定义以下的接口。public interface calrect {\x0d\x0apublic abstract int calarea()\x0d\x0apublic abstract int calgirth()\x0d\x0apublic abstract int getx()\x0d\x0apublic abstract int gety()\x0d\x0a}注意,定义接口就像定义类一样,接口的访问控制符只能用public,用public定义的接口可以被所有的类和包引用,而缺省的则只能被同一个包中的其他类和接口引用,这符合JAVA中访问控制符的一般要求,关于接口再引用其他接口则是后话。以上接口文件名为calrect.java.另外需要指出的是接口中不能给方法给出方法体。接下来,需要定义一个类来实现接口,因为不知道JAVA的内置矩形类是什么名,所以为了安全,将该类定义为RRect,这可以认为是一种安全策略。关于implements,可以参考其他资料。该类引用了接口calrect,所以必须对calrect中的方法一一实现。//定义矩形类 应用接口class RRect implements calrect{private int x\x0d\x0aprivate int ypublic RRect (){\x0d\x0a x=3y=4\x0d\x0a}\x0d\x0apublic int calarea(){\x0d\x0a return x*y\x0d\x0a}\x0d\x0apublic int calgirth(){\x0d\x0a return x*2+y*2\x0d\x0a}\x0d\x0apublic int getx(){\x0d\x0a return x\x0d\x0a}\x0d\x0apublic int gety(){\x0d\x0a return y\x0d\x0a}\x0d\x0a}//接下来,定义一个测试类,所谓测试类,我理解为定义一个类,在其定义类RRect的对象,并验证其中的方法,看看是不是可以正常使用//定义Class1类\x0d\x0apublic class Class1{\x0d\x0aRRect rect\x0d\x0apublic static void main(String []args){\x0d\x0a RRect rect=new RRect()\x0d\x0a System.out.println("矩阵的长"+ rect.getx())\x0d\x0a System.out.println("矩阵的宽"+ rect.calarea())\x0d\x0a System.out.println("矩阵的面积"+ rect.calarea())\x0d\x0a System.out.println("矩形的周长 "+rect.calgirth())\x0d\x0a}\x0d\x0a\x0d\x0a}运行结果:矩阵的长3\x0d\x0a矩阵的宽12\x0d\x0a矩阵的面积12\x0d\x0a矩形的周长 14注:接口单存放,接口实现类和测试类可以存放在一个文件中

接口是很重要的面向对象方式,继承接口的类不用全部实现定义的接口,可以这么说,我定义了好多接口,某个类可以这么实现这个接口,到另一个类你又想那么实现接口,都是可以的。

或者定义完接口不想管他都可以,虽然很冗余。接口不多了不影响操作。

比如:

定义了一个线性表接口。

public interface Ilist {

public void clear()

public boolean isEmpty()

public int length()

}

我想具体实现的话就建立以下实现类:

import dao.Ilist

public class SqList implements Ilist {

private Object[] listElem// 线性表存储空间

private int curLen// 线性表的当前长度

// 顺序表的构造函数,构造一个存储空间容量为maxSize的线性表

public SqList(int maxSize) {

curLen = 0

listElem = new Object[maxSize]

}

public void clear() {

curLen = 0

}

public boolean isEmpty() {

return curLen == 0// curLen==0时为true,!=0时为false

}

public int length() {

return curLen

}

Java lang Comparable接口中唯一的方法是pareTo() 在该方法中可以进行简单的相等比较以及执行顺序比较 接口实现框架如下 [java] view plaincopyprint?

public class ComparableImpl implements Comparable<ComparableImpl>{

@Override public int pareTo(ComparableImpl o) { // TODO Auto generated method stub return }

}一个类实现了Comparable接口 则说明它的实例具有内在的排序关系 就可以跟多种泛型算法以及依赖于该接口的集合实现进行协作 依赖于比较关系的类包括有序集合类TreeSet和TreeMap 以及工具类Collections和Arrays 若一个数组中的元素实现了Comparable接口 则可以直接使用Arrays类的sort方法对这个数组进行排序 Java平台库中的所有值类(value classes)都实现了Comparable接口

Comparable的规范说明如下 将当前这个对象与指定对象进行顺序比较 当该对象小于 等于或大于指定对象时 分别返回一个负整数 零或者正整数 如果由于指定对象的类型而使得无法进行比较 则抛出ClassCastException异常

pareTo方法的实现必须满足如下几个限制条件 自反性 对称性 传递性和非空性

一般来说 paraTo方法的相等测试应该返回与equals方法相同的结果 如果相同 则由pareTo方法施加的顺序关系被称为 与equals一致 如果不同 则顺序关系被称为 与equals不一致 如果一个类的pareTo方法与equals方法的顺序关系不一致 那么它仍然能正常工作 只是 如果一个有序集合包含了该类的实例 则这个集合可能无法遵循某些集合接口的通用约定 因为集合接口的通用约定是按照equals方法定义的 而有序集合使用了由pareTo施加的相等测试 下面是实现了Comparable接口的类 同时 该类还重写了equals和hashCode等方法 [java] view plaincopyprint?

public abstract class ZLTextPosition implements Comparable<ZLTextPosition>{

public abstract int getParagraphIndex() public abstract int getElementIndex() public abstract int getCharIndex()

public boolean samePositionAs(ZLTextPosition position) { return getParagraphIndex() == position getParagraphIndex() &&getElementIndex() == position getElementIndex() &&getCharIndex() == position getCharIndex() }

@Override public int pareTo(ZLTextPosition position) { final int p = getParagraphIndex() final int p = position getParagraphIndex() if (p != p ) { return p <p ? }

final int e = getElementIndex() final int e = position getElementIndex() if (e != e ) { return e <e ? }

final int c = getCharIndex() final int c = position getCharIndex() if (c != c ) { return c <c ? } return }

@Override public boolean equals(Object obj) { if (this == obj) { return true } if (!(obj instanceof ZLTextPosition)) { return false }

final ZLTextPosition position = (ZLTextPosition)obj return samePositionAs(position) }

@Override public int hashCode() { return (getParagraphIndex() <<) + (getElementIndex() <<) + getCharIndex() }

@Override public String toString() { return getClass() getName() + + getParagraphIndex() + + getElementIndex() + + getCharIndex() }

lishixinzhi/Article/program/Java/hx/201311/26372