Chapter4 Item14 在公有类中使用访问方法而不是公有域

你可能偶尔需要编写退化类,目的只是为了集中实例域:

 // Degenerate classes like this should not be public!
   class Point {
       public double x;
       public double y;
   }

标准写法是:

// Encapsulation of data by accessor and mutators  
class Point {  
  private double x;  
  private double y;  
  
  public Point(double x, double y) {  
    this.x = x;  
    this.y = y;  
  }  
  
  public double getX() { return x; }  
  public double getY() { return y; }  
  public void setX(double x) { this.x = x; }  
  public void setY(double y) { this.y = y; }  
} 

如果一个类可以被包外访问,那么就要提供访问方法,以便可以灵活地改变类的内部表示。如果public类暴露了其数据域,则要想在将来改变内部表示是不可能的,因为他的客户端代码可能已经遍布各处了。
然而,如果类是package-private或是private嵌套类,那么把数据域暴露出去并没有本质的错误——假设这些数据域充分描述了该类提供的抽象。无论是在类定义中,还是在客户端代码中,这种方法相对于访问方法更不会产生视觉混乱。虽然客户端代码与类的内部表示紧密相连,但这些代码被限定在同一个包中。如果需要改变内部数据表示,你不必修改包外的任何代码。如果是private嵌套类,则甚至不需要修改类外的任何代码。

除非修改其API,否则你不能修改其内部数据表示,而且当别人读取该字段时 你不能采取任何附加行动,但是你可以强加约束条件(——因为只有你自己可以set该字段)
补救办法: public域加入约束条件

// public class with exposed immutable fields - questionable  
public final class Time {  
  private static final int HOUR_PER_DAY = 24;  
  private static final int MINUTES_PER_HOUR = 60;  
  
  public final int hour;  
  public final int minute;  
  
  public Time() {  
    //强加约束条件  
    if (hour < 0 || hour >= HOUR_PER_DAY) {  
       throw new IllegalArgumentException();  
    if (minute < 0 || minute >= MINUTES_PER_HOUR) {  
       throw new IllegalArgumentException();  
      
    this.hour = hour;  
    this.minute = minute;  
  }  
  
}

Summary

public类永远不要暴露其可变的字段。而public类暴露其不可变字段虽然是有问题,但危害性要小一些。然而,package-private或者private的嵌套类暴露其字段则是可行的,无论该字段是可变还是非可变。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 31,767评论 18 399
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,987评论 19 139
  • 前言 人生苦多,快来 Kotlin ,快速学习Kotlin! 什么是Kotlin? Kotlin 是种静态类型编程...
    任半生嚣狂阅读 26,282评论 9 118
  • 不知道你最近怎么样,莫名想你 。 说实话,我现在也不是很好 此前一个月,什么也没做,毫无长进。虚度了时光,浪费大好...
    泠弋阅读 349评论 0 0
  • 转载请注明出处,感谢您的支持。同时,欢迎加入移动开发学习交流qq群 : 450302004,互相学习。文章来源:【...
    chenyk阅读 538评论 0 11