Modifier ‘public‘ is redundant for interface methods详解

@[TOC] 目录

一、问题的发现

请看下边一段代码,并没有发现不妥之处,在Eclipse中也没有发现什么问题,之前也一直这么写的,但是在IDEA上这么写的时候会发现有警告(看下边截图),内容说是public是多余的,这是为什么呢?

public interface AdvancedMediaPlayer {
     

    /**
     *
     * @param fileName
     */
    public void playAvi(String fileName);

    /**
     *
     * @param fileName
     */
    public void playMp4(String fileName);
}

Modifier ‘public‘ is redundant for interface methods详解_第1张图片

二、思考

经过思考后,确实接口默认都是public abstract的,各种教材上都有这么说,但是怎么验证呢,还是通过反编译把plublic去掉的class文件看一下到底是什么样子的。

2.1 方法不带public的反编译结果

在这里插入图片描述

2.2 方法带public的反编译结果

在这里插入图片描述

2.3 结论

通过看2.1和2.2的反编译结果我们发现,在编译期虚拟机会进行优化统一编译成通过public abstract修饰,所以说IDEA编译器认为是多余的,少敲一个public,多敲其他的业务代码,哈哈。

三、推广

欢迎大家关注“程序猿每日分享”,和我们一起happy,一起浪。

你可能感兴趣的:(JAVA,精通EXCEPTION之路,java,intellij,idea)