我现在正在学习Java中的Abstract类,我想知道。
将包私有字段视为不良做法吗?
例如:

abstract class Parent {
    String testField;

    public void method() {
        System.out.println(testField);
    }
}


然后在儿童班上我会做

public final class Children extends Parent {

    @Override
    public void method() {
        logger.log(testField);
    }

}


在这个例子中,这是不好的做法吗?
还是我应该将它们设为私有,而是像往常一样为它们使用getter和setter?

最佳答案

这取决于您想做什么。但是,在许多情况下,封装或信息隐藏可能是有用的原理。在您的情况下,这意味着将成员变量设置为protectedprivate并仅通过getter / setter公开它,或者根本不公开。这产生了一些优点:


您可以更改类的实现(例如,更改testField的类型),而无需破坏其他程序员的代码
该代码对于其他程序员而言更加清晰,因为他们只需要考虑公共方法
它使代码更易于测试
它不鼓励令人羡慕和紧密耦合

09-11 17:32