封装通过隐藏实现细节、暴露有限接口来降低系统复杂度;基础做法是将字段设为private,仅提供public的getter/setter或业务方法,如银行账户类中balance私有,deposit和withdraw方法控制存取逻辑。

封装通过隐藏实现细节、暴露有限接口,让调用者无需理解内部逻辑就能安全使用功能,从而显著降低系统复杂度。
把数据和操作绑定在类里
封装最基础的做法是把字段设为 private,只提供 public 的 getter/setter 或业务方法。这样外部不能随意修改对象状态,也避免了因直接访问字段引发的错误。
例如一个银行账户类:
class Account {private double balance = 0.0;
public void deposit(double amount) {
if (amount > 0) balance += amount;
}
public boolean withdraw(double amount) {
if (amount > 0 && amount balance -= amount;
return true;
}
return false;
}
}
调用方只需关心“存”“取”行为是否成功,不用管余额怎么存、校验逻辑怎么写。
立即学习“Java免费学习笔记(深入)”;
用接口定义契约,屏蔽实现变化
定义 interface 或 abstract class,让不同实现类统一对外提供相同方法签名。上层代码依赖接口编程,不依赖具体类。
- 新增支付方式(如 Apple Pay、Alipay)只需新增实现类,不改原有调用逻辑
- 测试时可用 Mock 实现快速替换,无需启动真实服务
- 重构数据库访问层时,只要接口不变,业务代码完全无感
控制访问范围,分层暴露能力
Java 的 private / protected / package-private / public 四级访问修饰符,是模块化的重要工具:
- private:仅限本类使用,彻底隔绝外部干扰
- package-private(默认):适合同一模块内协作,比如 utils 包里的工具方法
- protected:留给子类扩展,但不对外公开(如模板方法模式中的钩子方法)
- public:仅保留真正需要被其他模块调用的方法,宁少勿多
过度暴露 public 方法会让类越来越难维护,也增加误用风险。
配合模块化(Java 9+ Module System)进一步解耦
用 module-info.java 明确声明哪些包对外开放:
module com.example.order {exports com.example.order.api;
requires com.example.payment.api;
}
这样:
- 其他模块无法访问
com.example.order.internal包下的类 - 编译期就能发现非法跨模块调用
- 运行时类加载更轻量,提升启动速度和安全性
封装 + 模块化,相当于给代码加了双重“隔离墙”。
基本上就这些。封装不是为了“藏起来”,而是为了“说清楚能做什么、不能做什么”。模块化则是把这种清晰性从类级别放大到系统级别。不复杂,但容易忽略。










