atwood-pan

 

Java-10接口与抽象类

Java-10接口与抽象类

抽象方法

abstract method机制

这是一个不完整的方法,它只有一个声明,没有方法体

abstract void f();

包含抽象方法的类被称为抽象类:如果一个类包含一个或多个抽象方法,则该类必须被定义为抽象类

public abstract class Basic {
/**
* 1、抽象类不能够被实例化
* 2、包含抽象方法的类称为抽象类
* 3、如果一个类包含一个或多个抽象方法,则该类必须被定义为抽象类
*/
abstract void unimplemented();
abstract void f();
}

抽象类不能够被实例化

public class AbstractTest {
public static void main(String[] args) {
// java: org.example.onjava.example10.abstract_class.Basic是抽象的; 无法实例化
// Basic basic = new Basic();
}
}

如果一个新类型继承了抽象类,并希望能生成自己的对象,那它必须为基类中的所有抽象方法提供方法定义,也就是说必须重写抽象类中所有抽象方法

public abstract class Basic {
/**
* 1、抽象类不能够被实例化
* 2、包含抽象方法的类称为抽象类
* 3、如果一个类包含一个或多个抽象方法,则该类必须被定义为抽象类
*/
public abstract void unimplemented();
public abstract void f();
}
public class Basic2 extends Basic {
// 【注意】继承抽象类后,需要为所有的抽象方法提供定义
@Override
public void unimplemented() {
System.out.println("Basic2.unimplemented");
}
@Override
public void f() {
System.out.println("Basic2.f");
}
}

一个抽象类可以不包含任何抽象方法。

如果一个类并不需要包含抽象方法,但同时还想阻止对它任何实例化,这时将其定义为抽象类就好了

public abstract class Basic3 {
int f(){
return 666;
}
// 没有抽象方法......
public static void main(String[] args) {
Basic3 basic3 = new Basic3();
//Basic3是抽象的; 无法实例化
}
}

接口

⚠️接口中只允许有public 方法,默认的访问权限修饰符就是public

我们使用关键字interface来定义接口

接口如果不加上public关键字,将获得包访问权限,这样的话该接口就只能在同一个包内使用

public interface AnInterface {
/**
* "所有实现了这个特定接口的类看起来都像这样" -> 任何使用了特定接口的代码都知道可以为该接口调用哪些方法
* 接口是用来在类之间建立"协议"
* 接口通常暗示 "类的类型"
* 1、interface关键字创建了一个完全抽象的类,它不代表任何实现
* 2、接口描述了一个类应该是什么样子的和做什么的,而不是应该怎么做
* 3、它确定了方法名、参数列表和返回类型,但不提供方法主体
* 4、接口只提供一种形式,并且除了某些受限制的情况外,它通常不提供实现
*
*/
int method01();
void method02();
double method03();
boolean method04(int a, int b);
}

接口也可以包含字段,但这些字段是隐式的static和final

要创建一个符合特定接口的类,使用implements【支持多实现】

/**
* @Author Coder_Pans
* @Date 2022/11/16 10:05
* @PackageName:org.example.onjava.example10.interface_demo.impl
* @ClassName: Implementation
* @Description: TODO Concept接口的实现类
* @Version 1.0
*/
public class Implementation implements Concept, AnInterface {// 实现多个接口用逗号隔开
@Override
public int method01() {
return Concept.i;// 接口中的字段:默认是static和final的
}
@Override
public void method02() {
System.out.println("我实现了Concept接口......");
}
@Override
public double method03() {
return 0;
}
@Override
public boolean method04(int a, int b) {
return a > b;
}
}

默认方法

当在接口中使用default时,default会允许方法创建一个方法体,实现了该接口的类可以在不定义方法[不实现该方法]的情况下直接替换方法体

/**
*
* 带有默认方法的接口
*/
public interface InterfaceWithDefault {
void firstMethod();
void secondMethod();
// 默认方法
default void newMethod(){
System.out.println("default会允许接口中的方法创建一个方法体," +
"实现了该接口的类可以在不定义方法的情况下直接替换方法体.!>?" +
"Java8之前不可以default" +
"实现类可以不实现default方法,但也可以直接调用");
}
}
/**
* @Author Coder_Pans
* @Date 2022/11/16 10:14
* @PackageName:org.example.onjava.example10.interface_demo.impl
* @ClassName: DefaultMethodImpl
* @Description: TODO 实现带有默认方法的接口
* @Version 1.0
*/
public class DefaultMethodImpl implements InterfaceWithDefault {
@Override
public void firstMethod() {
System.out.println("DefaultMethodImpl.firstMethod()");
}
@Override
public void secondMethod() {
System.out.println("DefaultMethodImpl.secondMethod()");
}
// 该实现类没有实现InterfaceWithDefault中的default方法
public static void main(String[] args) {
DefaultMethodImpl defaultMethod = new DefaultMethodImpl();
defaultMethod.firstMethod();
defaultMethod.secondMethod();
defaultMethod.newMethod();// 没有实现也可以直接调用
}
}

⚠️返回值类型不是方法签名的一部分,不能够用来区分两个方法

接口中的静态方法

定义模版方法(Template Method)

/**
* @Author Coder_Pans
* @Date 2022/11/16 10:22
* @PackageName:org.example.onjava.example10.interface_demo.interfaces
* @ClassName: Operation
* @Description: TODO 接口中 的 静态方法
* @Version 1.0
*/
public interface Operation {
void execute();
// 设计模式 -> 模版方法(Template Method)
// 根据需要传递任意数量的Operation参数,按顺序运行
static void runOps(Operation... ops){
for (Operation op : ops){
op.execute();
}
}
// 接口中 的 静态方法
static void show(String msg){
System.out.println(msg);
}
}

runOps()使用可变参数列表,可以根据需要传递任意数量的参数,并且顺序运行.....

/**
* @Author Coder_Pans
* @Date 2022/11/16 10:27
* @PackageName:org.example.onjava.example10.interface_demo.impl
* @ClassName: MetalWork
* @Description: TODO
* @Version 1.0
*/
class Heat implements Operation {
@Override
public void execute() {
Operation.show("Heat......");
}
}
public class MetalWork {
public static void main(String[] args) {
Operation twist = new Operation() {
@Override
public void execute() {
Operation.show("Twist......");
}
};
Operation.runOps(
new Heat(), // 常规类
new Operation() {// 匿名类
@Override
public void execute() {
Operation.show("Hammer......");
}
},
twist :: execute,// 方法引用
() -> Operation.show("Lambda......")// lambda表达式
);
}
}

抽象类和接口

二者之间的区别


抽象类仍然是一个类,在创建新类时只能继承它一个。而创建类的过程中可以实现 多个接口。【爱是抽象且唯一的!

组合多个接口

需要将所 有的接口名称置于 implements 关键字之后且用逗号分隔。可以有任意多个接口,并可以向上转型为每个接口,因为每个接口都是独立的类型。

/**
* @Author Coder_Pans
* @Date 2022/11/16 10:44
* @PackageName:org.example.onjava.example10.interface_demo.impl
* @ClassName: Adventure
* @Description: TODO 组合多个接口,接口的多继承
* @Version 1.0
*/
public class Adventure {
public static void main(String[] args) {
}
}
/**
* 需要将所 有的接口名称置于 implements 关键字之后且用逗号分隔。
* 可以有任意多个接口,并可以向上转型为每个接口,因为每个接口都是独立的类型。
*/
class Hero extends D
implements A, B, C{
@Override
public void aMethod() {
}
@Override
public void bMethod() {
}
@Override
public void cMethod() {
}
}
interface A{
void aMethod();
}
interface B{
void bMethod();
}
interface C{
void cMethod();
}
class D{
public void dMethod(){
System.out.println("dMethod......");
}
}

posted on   JavaCoderPan  阅读(38)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南

导航

统计

点击右上角即可分享
微信分享提示