标签:定义 这不 ram 类方法 需要 type 方法 something author
以前,接口里的方法要求全部是抽象方法,java8以后允许在接口里定义默认方法和类方法。不同的是:默认方法可以通过实现接口的类实例化的对象来调用,而类方法就相对于工具方法了。需要注意的是,此处的静态方法只能被public修饰(或者省略不写),不能是private或者protected。
好处:在Java 8 之前,接口不能有静态方法,因此按照惯例,接口Type 的静态工厂方法被放一个名为ypes 的不可实例化的伴生类中。例如Java Collections Framework的集合接口有45 个工具实现,分别提供了不可修改的集合、同步集合,等等。几乎所有这些实现都通过静态工厂方法在-个不可实例化的类( java . ut il. Collections ) 中导出。所有返回对象的类都是非公有的。现在的Collections Framework API 比导出45 个独立公有类的那种实现方式要小得多,每种便利实现都对应一个类。这不仅仅是指API 数量上的减少,也是概念意义上的减少:为了使用这个API,用户必须掌握的概念在数量和难度上都减少了。
interface DemoInterface { default void doSomething() { System.out.println("默认方法-->test1"); } static void test() { System.out.println("这个是一个静态方法"); } } interface Demo1Interface { default void doSomething() { System.out.println("默认方法-->test2"); } } public class Test implements DemoInterface { public static void main(String[] args) { Test test = new Test(); test.doSomething(); DemoInterface.test(); //NutritionFacts tFacts = new NutritionFacts.Builder(1, 2).calotes(2).build(); } }
/** * * 此类描述的是:实现两个接口时,并且两个接口的方法相同时,必须要实现 * * @author: Aarony * @version: 2019年5月24日 上午10:03:45 */ public class Test1 implements DemoInterface, Demo1Interface { public static void main(String[] args) { Test1 test = new Test1(); test.doSomething(); } // 假如下面是Demo1Interface,输出test2,DemoInterface 输出test1 @Override public void doSomething() { DemoInterface.super.doSomething(); // Demo1Interface.super.doSomething(); } }
标签:定义 这不 ram 类方法 需要 type 方法 something author
原文地址:https://www.cnblogs.com/wucaifang/p/10916484.html