我现在正在学习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?
最佳答案
这取决于您想做什么。但是,在许多情况下,封装或信息隐藏可能是有用的原理。在您的情况下,这意味着将成员变量设置为protected
或private
并仅通过getter / setter公开它,或者根本不公开。这产生了一些优点:
您可以更改类的实现(例如,更改testField的类型),而无需破坏其他程序员的代码
该代码对于其他程序员而言更加清晰,因为他们只需要考虑公共方法
它使代码更易于测试
它不鼓励令人羡慕和紧密耦合