java接口修饰符可以为_java 接口默认修饰符

概论:

java接口可以是public 的,也可以是friendly的,但一定是abstracted的。

java接口里的方法只能是public的、abstract的。

java接口里的成员变量只能是public 的,static 的,final的;并且必须赋初值,否则通不过编译。

C++支持多重继承,如果两个父类有相同的成员变量,处理起来比较困难。java 接口的成员变量之所以这样设计,就是为了解决C++ 中的这个问题。成员变量必须是static 的,所以接口里的成员变量就不再属于某个对象,而是属于这个接口的。子类的对象里就没有父类的这个成员变量。

那怎样使用父类里的成员变量呢?

public interfaceFather {int i = 0;

}

public interfaceFather2 {int i = 2;

}

public class Son implementsFather, Father2 {static int i = 3;public static voidmain(String[] args) {

System.out.println(Father.i);

System.out.println(Father2.i);

System.out.println(i);

}

}

接口问题:

实现两个接口,这两个接口里有两个签名相同,返回值不同的方法。一个类同时实现,报错。

package test;

public interface InterfaceTest {

void todo();

}

/**

* 以下是反编译的内容,接口默认是abstract的,

* 接口里的方法默认都是public的、abstract的。

*

package test;

public abstract interface InterfaceTest {

public abstract void todo();

}

*/

上面用得是第三方的一个反编译工具,

用 Eclipse 反编译插件编译后的结果却不同,如下:

package test;

public  interface InterfaceTest {

void todo();

}

接下来一探究竟:

1.创建一个java 接口:

public interface TestInterface {

void say();

}

2.为这个接口添加一个abstract 修饰符

public abstract interface TestInterface {

void say();

}

结果一切正常,它的实现类运行毫不影响。由此可知java接口默认就是abstract的。

3、去掉这个接口的public 修饰符

interface TestInterface {

void say();

}

不报错;同包下的实现类运行正常;异包下的实现类通不过编译。由此可知java接口本身可以是friendly的(但不可以是private 和protected 的,这和类的声明是一致的)。

4、为这个接口里的一个方法添加private 修饰符

public interface TestInterface {

private void say();

}

通不过编译。由此可知java接口里的方法不可以是private 的。

5、为这个接口里的一个方法添加protected 修饰符

public interface TestInterface {

protected void say();

}

通不过编译。由此可知java接口里的方法不可以是protected 的。

6、为这个接口里的一个方法添加abstract 修饰符

public interface TestInterface {

abstract void say();

}

一切正常,它的实现类运行毫不影响。由此可知java接口里的方法默认就是abstract 的。

总结:

java接口本身默认是abstract的;可以是public的,也可以是friendly的,但不可以是private 的,不可以是protected的(否则通不过编译)。

java接口里的方法默认是abstract的,public 的;不可以private 的,不可以是protected 的。

还得出一个结果,这个第三方的反编译工具更准确。下载地址:https://i.cnblogs.com/Files.aspx 文件名:javaDecompiler.rar


版权声明:本文为weixin_34871733原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。