您的位置:首页 > 编程语言 > Java开发

Java之嵌套接口详解(附源码)

2016-07-21 11:51 771 查看

示例源码

接口可以嵌套在类或其他接口中。这揭示了许多非常有趣的特性:

package com.mufeng.theninthchapter;

class A {
interface B {
void f();
}

public class BImp implements B {

@Override
public void f() {
// TODO Auto-generated method stub

}
}

private class BImp2 implements B {

@Override
public void f() {
// TODO Auto-generated method stub

}
}

public interface C {
void f();
}

class CImp implements C {

@Override
public void f() {
// TODO Auto-generated method stub

}
}

private class CImp2 implements C {

@Override
public void f() {
// TODO Auto-generated method stub

}

}

private interface D {
void f();
}

private class DImp implements D {

@Override
public void f() {
// TODO Auto-generated method stub

}
}

public class DImp2 implements D {

@Override
public void f() {
// TODO Auto-generated method stub

}
}

public D getD() {
return new DImp2();
}

private D dRef;

public void receiveD(D d) {
dRef = d;
dRef.f();
}
}

interface E {
interface G {
void f();
}

public interface H {
void f();
}

void g();

// Cannot be private within an interface:
// private interface I{
// void f();
// }
}

public class NestingInterfaces {

public class BImp implements A.B {

@Override
public void f() {
// TODO Auto-generated method stub

}
}

class CImp implements A.C {

@Override
public void f() {
// TODO Auto-generated method stub

}
}

// Cannot implement a private interface except
// within that interface's defining class
// class DImp implements A.D {
// @Override
// public void f() {
// // TODO Auto-generated method stub
//
// }
// }

class EImp implements E {

@Override
public void g() {
// TODO Auto-generated method stub

}
}

class EGImp implements E.G {

@Override
public void f() {
// TODO Auto-generated method stub

}

}

class EImp2 implements E {

@Override
public void g() {
// TODO Auto-generated method stub

}

class EG implements E.G {

@Override
public void f() {
// TODO Auto-generated method stub

}

}
}

public static void main(String[] args) {
A a = new A();
// Can't access A.D
// !A.D ad=a.getD();

// Doesn't return anything but A.D
//!A.DImp2 di2 = a.getD();

//Cannot access a member of the interface
//!a.getD().f();

//Only another A can do anything with getD():
A a2=new A();
a2.receiveD(a.getD());
}

}


源码解析

在类中嵌套接口的语法是相当显而易见的,就像非嵌套接口一样,可以拥有public和“包访问”两种可视性。
作为一种新添加的方式,接口也可以被实现为private的,就像在A.D中所看到的(相同的语法既适用于嵌套接口,也适用于嵌套类)。那么private的嵌套接口能带来什么好处呢?读者可能会猜想,它只能够被实现为DImple中的一个private内部类,但是A.DImp2展示了它同样可以被实现为public类。但是,A.DImp2只能被其自身所使用。你无法说它实现了一个private接口D。因此,实现一个private接口只是一种方式,它可以强制该接口中的方法定义不要添加任何类型信息(也就是说,不允许向上转型)。
getD()方法使我们陷入了一个进退两难的境地,这个问题与private接口相关:它是一个返回对private接口的引用的public方法。你对这个方法的返回值能做些什么呢?在main()中,可以看到数次尝试使用返回值的行为都失败了。只有一种方式可成功,那就是将返回值交给有权使用它的对象。在本例中,是另一个A通过receiveD()方法来实现的。
接口E说明接口彼此之间也可以嵌套。然而,作用于接口的各种规则,特别是所有的接口元素必须是public的,在此都会被严格执行。因此,嵌套在另一个接口中的接口自动就是public的,而不能声明为private
NestingInterfaces展示了嵌套接口的各种实现方式。特别要注意的是,当实现某个接口时,并不需要实现嵌套在其内部的任何接口。而且,private接口不能在定义它的类之外被实现。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: