开发者社区> 问答> 正文

Java Abstract类的良好做法

我现在正在学习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?

问题来源:Stack Overflow

展开
收起
montos 2020-03-26 22:52:21 446 0
1 条回答
写回答
取消 提交回答
  • 这取决于您想做什么。但是,在许多情况下,封装或信息隐藏可能是有用的原理。在您的情况下,这意味着使成员变量成为可能,protected或者private仅通过getter / setter公开它,或者根本不公开。这产生了一些优点:

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

    回答来源:Stack Overflow

    2020-03-26 22:52:48
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
Spring Cloud Alibaba - 重新定义 Java Cloud-Native 立即下载
The Reactive Cloud Native Arch 立即下载
JAVA开发手册1.5.0 立即下载