mou*_*dug 6 java findbugs accessor getter-setter
Findbugs在我的代码上报告了很多EI_EXPOSE_REP和EI_EXPOSE_REP2错误,每次我写这样的getter和setter:
public Date getDate() {
return date;
}
public void setDate(final Date date) {
this.date = date;
}
Run Code Online (Sandbox Code Playgroud)
我理解报告的含义,我不应该将我的objet的内部引用暴露给外部世界,以便它们不会被恶意/错误的代码修改.修复将是:
public Date getDate() {
return date == null ? null : date.clone();
}
public void setDate(Date date) {
this.date = date == null ? null : date.clone();
}
Run Code Online (Sandbox Code Playgroud)
我的问题不在这里.我很惊讶这份报告关注的是ALWAYS Date.为什么不是所有其他可变对象?我认为这份报告也适用于所有可变对象,不是吗?
我是否应该将这种"良好做法"扩展到我处理可变对象的所有访问者?
给我你的建议,谢谢
我当然希望这份报告与所有可变对象相关,但我怀疑 FindBugs 知道某些常见的违规者。
我通常会小心地通过吸气剂暴露内部状态,例如
public ArrayList<Trade> getTrades() {
return trades;
}
Run Code Online (Sandbox Code Playgroud)
方法
因此有两种方法。
类似的参数涉及 setter 和构造函数参数。
请注意,您可能会发现自己在暴露后复制了很多对象以保护自己,并且可能会做很多额外的工作。这是一种需要谨慎使用的技术,值得了解您的客户对象是谁,以及您是否可以控制和/或信任他们。
| 归档时间: |
|
| 查看次数: |
8222 次 |
| 最近记录: |