为什么 getter 和 setter 方法在 java 中很重要?

2022-09-01 04:51:12

我被教导总是使用getter和setters。但是,我不知道这些方法的优缺点,因为通过实现它们,我们正在公开数据并隐藏它。

我对此有点困惑。任何人都可以就我们为什么使用getter/setter以及优势是什么给出一些适当的建议吗?


答案 1

基本的“私有字段,具有公共 getter 和 setter,除了返回或设置字段之外什么都不做”模式在封装方面确实完全没有意义,除了它让你有机会在不更改 API 的情况下稍后更改它。

所以不要不假思索地使用这种模式。仔细考虑您实际需要的操作。

getters 和 setter 的真正意义在于,你应该只在合适的地方使用它们,而且它们可以做的不仅仅是获取和设置字段。

  • 你只能有一个获取器。然后,该属性是只读的。这实际上应该是最常见的情况。
  • 您只能有一个 setter,使属性可配置,但传达的是,其他任何内容都不应依赖于其值
  • getter 可以从多个字段计算值,而不是返回一个字段。
  • 一个获取者可以制作一个防御性的副本
  • getter 可以懒惰地执行成本高昂的提取操作,并使用字段来缓存值
  • 二传手可以进行健全性检查并投掷IllegalArgumentException
  • 设置者可以通知侦听器值的更改
  • 您可以有一个将多个字段设置在一起的 setter,因为它们在概念上属于一起。这不符合JavaBeans规范,所以如果你依赖于需要JavaBeans的框架或工具,就不要这样做。否则,这是一个有用的选择。

所有这些都是隐藏在简单的“getter and setter”接口后面的实现细节。这就是封装的意义所在。


答案 2

getter 和 setter 的思想是控制对类中变量的访问。这样,如果需要在内部更改值以以不同的方式表示,则可以在不破坏类外部任何代码的情况下执行此操作。

例如,假设您有一个带有距离变量的类,并且以英寸为单位进行测量。几个月过去了,你在很多地方使用这个类,你突然意识到你需要用厘米来表示这个值。如果您没有使用 getter 和 setter,则必须跟踪该类的每次使用并在那里进行转换。如果您使用了 getter 和 setter,则只需更改这些方法,使用该类的所有内容都不会中断。

public class Measurement
{

    /**
     * The distance in centimeters.
     */
    private double distance;

    /**
     * Gets the distance in inches.
     * @return A distance value.
     */
    public double getDistance()
    {
        return distance / 2.54;
    }

    /**
     * Sets the distance.
     * @param distance The distance, in inches.
     */
    public void setDistance(double distance)
    {
        this.distance = distance * 2.54;
    }
}