微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

oop – 严格遵守单一责任原则是否违反了封装?

似乎如果我严格遵守单一责任原则,那么我可能必须添加公共getter以分割可能发生变化的功能.对我来说,这似乎违反了通过暴露对象内部结构的封装.

例如,假设我有一个表示上传文件的类.在过去,我使用像toHtml()这样的方法来避免getter并保持封装:

public class UploadedFile() {
  private String filename;
  private String uri;
  public String toHtml() {
    return <html string>;
 }

但我可以看到有人认为,基于SRP,您可能希望包含文件名和uri的getter,并在其他地方生成html.

解决方法

在这种情况下,filename和uri将是你的UploadedFile()类的属性,保持隐藏是不合逻辑的,所以在我看来,为那些提供getter并不违反封装.

如果您创建了文件名和uri公共字段并且只是直接访问它们,则会发生封装违规.

@H_502_28@

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐