引言

接口这个词在生活中我们并不陌生。

在中国大陆,我们可以将自己的家用电器的插头插到符合它插口的插座上;

我们在戴尔,惠普,联想,苹果等品牌电脑之间传输数据时,可以使用U盘进行传输。

插座的普适性是因为大部分都是国标的;U盘可以插到这些电脑上,是因为都遵循了USB2.0或者USB3.0的标准。

在遵循相同标准的前提下,就出现了接口。

接口的定义

由引言可知,接口就是多个类之间的公共规范。

我们知道,普通类的定义是这样的

public class 类名{

}

接口的定义把class换成interface便可以了,如下所示:

public interface 接口名{

}

接口中定义抽象方法

接口中抽象方法的定义如下:

public abstract 方法返回类型 方法名();

其中public和abstract是可以省略的。从而,可以简写为如下形式:

方法返回类型 方法名();

接口的抽象方法的使用

接口是不能new对象实例的。那我们怎么调用接口的抽象方法呢?

我们需要新定义一个类来实现这个接口,然后覆盖重写接口中所有的抽象方法。其中实现接口的类定义方式如下:

public class 类名 implements 需要实现的接口名{
//重写所有抽象方法
}

比如,可以定义一个接口和一个实现类,然后再定义一个类,来调用方法。

package com.sjdwz;

/**
* @Description 接口示例代码
* @Date 2022/3/17
* @Created by 随机的未知 sjdwz.com
*/
public interface MyInterfaceStudy1 {
public abstract void test01();
}
package com.sjdwz;

/**
* @Description MyInterfaceStudy1接口的实现
* @Date 2022/3/17
* @Created by 随机的未知 sjdwz.com
*/
public class MyInterfaceStudy1Impl implements MyInterfaceStudy1{
@Override
public void test01() {
System.out.println("实现了接口MyInterfaceStudy1的test01方法");
}
}
package com.sjdwz;

/**
* @Description 接口抽象方法使用测试
* @Date 2022/3/17
* @Created by 随机的未知 sjdwz.com
*/
public class MyInterfaceStudyTest1 {
public static void main(String[] args) {
MyInterfaceStudy1Impl myInterfaceStudy1 = new MyInterfaceStudy1Impl();
myInterfaceStudy1.test01();
}
}

注意:如果没有覆盖重写所有的抽象方法,那么本实现类需要是一个抽象类。

接口中定义默认方法

假设某场景下,我们的接口需要进行升级,必须添加某些方法来满足新的需要,如果我们再定义抽象方法的话,那么我们之前实现该接口的所有非抽象类都需要重新进行修改。

那么有没有一种办法,能够让我们不改动接口实现类的代码就能完成接口的升级呢?

在Java8中对此给出了答案。

我们可以在接口中定义默认方法。

定义方式如下:

public default 方法返回类型 方法名(){
//方法里面需要执行的内容
}

public可以省略。

接口的默认方法的使用

我们在定义接口的实现类时,不需要对默认方法进行覆盖重写,就可以使用该方法。请看如下的例子:

接口类的定义

package com.sjdwz;

/**
* @Description 接口的默认方法
* @Date 2022/3/17
* @Created by 随机的未知 sjdwz.com
*/
public interface MyInterfaceStudy2 {
default void defaultFucTest01(){
System.out.println("我在defaultFucTest01中,我是一个默认方法,我解决了接口升级的问题");
}
void testAbstarct();
}

两个实现类的定义

package com.sjdwz;

/**
* @Description TODO
* @Date 2022/3/17
* @Created by 随机的未知 sjdwz.com
*/
public class MyInterfaceStudy2Impl implements MyInterfaceStudy2{
@Override
public void testAbstarct() {
System.out.println("我在MyInterfaceStudy2Impl中,我重写了MyInterfaceStudy2中的抽象方法");
}
}
package com.sjdwz;

/**
* @Description TODO
* @Date 2022/3/17
* @Created by 随机的未知 sjdwz.com
*/
public class MyInterfaceStudy2DefaultImpl implements MyInterfaceStudy2{
@Override
public void defaultFucTest01() {
System.out.println("我在MyInterfaceStudy2DefaultImpl中,我重写了MyInterfaceStudy2的默认方法");
}
@Override
public void testAbstarct() {
System.out.println("我在MyInterfaceStudy2DefaultImpl中,我重写了MyInterfaceStudy2的默认方法");
}
}

它们的使用:

package com.sjdwz;

/**
* @Description TODO
* @Date 2022/3/17
* @Created by 随机的未知 sjdwz.com
*/
public class MyInterfaceStudyTest2 {
public static void main(String[] args) {
MyInterfaceStudy2Impl myInterfaceStudy2 = new MyInterfaceStudy2Impl();
myInterfaceStudy2.defaultFucTest01();
myInterfaceStudy2.testAbstarct(); MyInterfaceStudy2DefaultImpl myInterfaceStudy2Default = new MyInterfaceStudy2DefaultImpl();
myInterfaceStudy2Default.defaultFucTest01();
myInterfaceStudy2Default.testAbstarct();
}
}

输出如下:

由此可见,接口实现类如果没有重写接口中的默认方法,会去调用接口中的默认方法;如果实现类重写了接口的默认方法,便会调用重写的方法。

接口中定义静态方法

定义方式如下

public static 方法返回类型 方法名(){
//方法里面需要执行的内容
}

public可以省略

接口的静态方法的使用

定义接口如下:

package com.sjdwz;
/**
* @Description 接口中的静态方法
* @Date 2022/3/17
* @Created by 随机的未知 sjdwz.com
*/
public interface MyInterfaceStudy3 {
static void staticFuc(){
System.out.println("我在MyInterfaceStudy3接口中,这是我的静态方法");
}
}

该接口的实现类如下

package com.sjdwz;

/**
* @Description 实现类
* @Date 2022/3/17
* @Created by 随机的未知 sjdwz.com
*/
public class MyInterfaceStudy3Impl implements MyInterfaceStudy3{
}

如果我使用方式如下可以吗?

强大的Java编辑器已经帮我们提示错误了。这样使用是不可以的。

正确使用方式时接口名.静态方法名(参数);

package com.sjdwz;

/**
* @Description 接口静态方法的使用测试
* @Date 2022/3/17
* @Created by 随机的未知 sjdwz.com
*/
public class MyInterfaceStudyTest3 {
public static void main(String[] args) {
MyInterfaceStudy3.staticFuc();
}
}

输出如下

接口中定义常量

定义方式如下

public static final 数据类型 常量名 = 666;

其中public static final可以省略。

一般常量名的每个字母都大写,如果时多个单词,使用下划线连接。

如下所示:

int NUM = 666;
int DAILY_HOURS = 24;

接口中常量的使用

定义接口如下:

package com.sjdwz;
/**
* @Description 接口中定义常量
* @Date 2022/3/17
* @Created by 随机的未知 sjdwz.com
*/
public interface MyInterfaceStudy4 {
int NUM = 666;
int DAILY_HOURS = 24;
}

实现类如下

package com.sjdwz;

/**
* @Description 实现类
* @Date 2022/3/17
* @Created by 随机的未知 sjdwz.com
*/
public class MyInterfaceStudy4Impl {
}

我们可以使用如下吗?

很明显,又提示错误了。不能使用实现类.常量实现类的对象.常量来使用。

正确使用如下:

package com.sjdwz;

/**
* @Description 接口的常量使用测试
* @Date 2022/3/17
* @Created by 随机的未知 sjdwz.com
*/
public class MyInterfaceStudyTest4 {
public static void main(String[] args) {
System.out.println("用接口来访问接口中的常量NUM:======"+MyInterfaceStudy4.NUM);
System.out.println("用接口来方法接口中的常量DAILY_HOURS:======"+MyInterfaceStudy4.DAILY_HOURS);
}
}

输出如下:

原文链接为:https://sjdwz.com/11171.html

详解java接口interface的更多相关文章

  1. 第十八节:详解Java抽象类和接口的区别

    前言 对于面向对象编程来说,抽象是它的特征之一. 在Java中,实现抽象的机制分两种,一为抽象类,二为接口. 抽象类为abstract class,接口为Interface. 今天来学习一下Java中 ...

  2. Protocol Buffer技术详解(Java实例)

    Protocol Buffer技术详解(Java实例) 该篇Blog和上一篇(C++实例)基本相同,只是面向于我们团队中的Java工程师,毕竟我们项目的前端部分是基于Android开发的,而且我们研发 ...

  3. 详解java动态代理机制以及使用场景

    详解java动态代理机制以及使用场景 https://blog.csdn.net/u011784767/article/details/78281384 深入理解java动态代理的实现机制 https ...

  4. 详解Java中的clone方法

    详解Java中的clone方法 参考:http://blog.csdn.net/zhangjg_blog/article/details/18369201/ 所谓的复制对象,首先要分配一个和源对象同样 ...

  5. 异常处理器详解 Java多线程异常处理机制 多线程中篇(四)

    在Thread中有异常处理器相关的方法 在ThreadGroup中也有相关的异常处理方法 示例 未检查异常 对于未检查异常,将会直接宕掉,主线程则继续运行,程序会继续运行 在主线程中能不能捕获呢? 我 ...

  6. 详解 Set接口

    (请关注 本人"集合"总集篇博文--<详解 Collection接口>) 在Collection接口的子接口中,最重要的,也是最常见的两个-- List接口 和 Set ...

  7. 「跬步千里」详解 Java 内存模型与原子性、可见性、有序性

    文题 "跬步千里" 主要是为了凸显这篇文章的基础性与重要性(狗头),并发编程这块的知识也确实主要围绕着 JMM 和三大性质来展开. 全文脉络如下: 1)为什么要学习并发编程? 2) ...

  8. 详解Java GC的工作原理+Minor GC、FullGC

    详解Java GC的工作原理+Minor GC.FullGC 引用地址:http://www.blogjava.net/ldwblog/archive/2013/07/24/401919.html J ...

  9. 详解EBS接口开发之库存事务处理采购接收--补充

    除了可以用  详解EBS接口开发之库存事务处理采购接收的方法还可以用一下方法,不同之处在于带有批次和序列控制的时候实现方式不同 The script will load records into ...

随机推荐

  1. js修改css

    转载请注明来源:https://www.cnblogs.com/hookjc/ <style type="text/css"> .style{font-size:9pt ...

  2. 从StoryBoard加载控制器

    1.创建窗口self.window = [[UIWindow alloc] initWithFrame:[UIScreen mainScreen].bounds];2.加载控制器从StoryBoard ...

  3. imagenamed和imageWithContentOfFile的区别

    @implementation ViewController /** 图片的两种加载方式: 1> imageNamed: a. 就算指向它的指针被销毁,该资源也不会被从内存中干掉 b. 放到As ...

  4. 区段统计 mysql 语句 case when then end as

    EXPLAIN SELECT COUNT(*),CASEWHEN device_width > 729 THEN '>729'WHEN device_width BETWEEN '720' ...

  5. requests库session保持持久会话

      requests中cookie的原理 http://blog.csdn.net/zhu_free/article/details/50563756   requests - cookies的实现例 ...

  6. 敲出的第一个python程序

    学习python第二天,终于照猫画虎编辑出第一个程序.程序要求如下: 1.输入用户名.密码 2.认证成功后显示欢迎信息 3.输错三次后锁定 源代码如下: username = 'jackson'pas ...

  7. VLAN介绍及实验

    目录 一.VLAN 1.1.VLAN的概念及优势 1.2.VLAN的种类 1.3.静态VLAN的配置 1.4.Trunk的作用 1.5.配置实验 1.搭建拓扑图 2.交换机SW1配置情况 3.交换机S ...

  8. 继承及属性查找+super()和mro()+多态

    继承及属性查找+super()和mro()+多态 一. ★继承 1. 什么是继承? 继承就是新建类的一种方式,新建的类我们称为子类或者叫派生类,被继承的类我们称为父类或者基类 子类可以使用父类中的属性 ...

  9. 35、python并发编程之多线程(理论篇)

    一 什么是线程 二 线程的创建开销小 三 线程与进程的区别 四 为何要用多线程 五 多线程的应用举例 六 经典的线程模型(了解) 七 POSIX线程(了解) 八 在用户空间实现的线程(了解) 九 在内 ...

  10. SonarQube之采购选型参考

    SonarQube是DevOps实践中主流的一款质量内建工具,过插件机制,Sonar 可以集成不同的测试工具,代码分析工具,以及持续集成工具,比如pmd-cpd.checkstyle.findbugs ...