Java访问修饰符决定可见性与封装强度:public开放接口需谨慎;protected支持安全继承;默认(包级私有)实现模块隔离;private保护实现细节。

Java中的访问修饰符是OOP设计的基石,直接决定类、方法、字段的可见范围和封装强度。用对了,能清晰划清模块边界、降低耦合、提升可维护性;用错了,轻则暴露内部实现,重则破坏封装原则,让继承和多态变得不可靠。
public:开放接口,但需谨慎暴露
被public修饰的成员可在任意位置访问。它适合定义对外提供的稳定API,比如工具类的静态方法(StringUtils.isEmpty())、服务接口(UserService.save())或DTO的getter/setter。但不要为所有字段都加public——这等于放弃封装。例如把一个账户余额字段设为public,外部代码就能随意修改,绕过校验逻辑。
protected:支持安全继承,限制包外直接调用
protected允许同一包内访问,也允许不同包的子类访问。这是实现“受控继承”的关键:父类把可被子类复用或重写的逻辑(如模板方法中的钩子方法)设为protected,既不对外公开,又保留扩展能力。注意:子类对象不能通过引用访问父类的protected字段(除非在子类自身代码中),这点常被误解。
默认(包级私有):天然的模块隔离墙
不写任何修饰符时,成员仅对同一包内的类可见。这是最常被低估的修饰符。它非常适合内部协作类——比如一个解析器包里,JsonParser调用TokenReader和NodeBuilder,三者同包,无需public,也不必暴露给其他模块。这种“包内友好、包外绝缘”的特性,是构建高内聚低耦合模块的实用手段。
立即学习“Java免费学习笔记(深入)”;
private:封装的最后防线
private严格限制在声明它的类内部使用。它保护的是实现细节:缓存字段、临时计算变量、辅助方法等。即使子类需要类似功能,也应通过protected方法间接获取,而不是直接访问父类private成员。例如,ArrayList的elementData数组是private,外界只能通过get()、add()等public方法操作,内部扩容、索引校验等逻辑完全隐藏。










