选接口还是抽象类取决于设计意图:接口定义“能做什么”的行为契约,适合多实现和能力组合;抽象类提供“怎么做的”代码骨架,适合共享逻辑和强制流程。

选接口还是抽象类,关键看你要解决什么问题:要定义“能做什么”,用接口;要提供“怎么做的基础模板”,用抽象类。
接口适合定义行为契约
接口描述的是能力,不关心实现细节。比如List、Runnable、Comparable,它们只说“你能被排序”“你能被运行”“你支持遍历”,不指定怎么排、怎么跑、怎么遍历。
- 一个类可以实现多个接口,天然支持多行为组合(比如一个类既可序列化又可比较)
- 接口方法默认是public abstract,字段默认是public static final
- JDK 8 后可以加default和static方法,但仍是为扩展服务,不是为了封装共用逻辑
抽象类适合共享代码骨架
当你有一组子类,它们有大量通用逻辑(比如初始化、校验、模板流程),只是某些步骤不同,就该用抽象类。
- 抽象类可以有构造器、普通字段、protected方法、静态方法、甚至具体实现的方法
- 子类继承它,自动获得复用代码,只需重写抽象方法或选择性覆盖已有方法
- 比如HttpServlet提供了service()主流程,子类只管写doGet()或doPost()
现实项目中经常一起用
大框架里常见“接口 + 抽象实现类”的组合。接口对外承诺能力,抽象类对内沉淀通用实现,留给具体子类最小定制成本。
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~