您很可能需要覆盖hashCode()
, equals(..)
和toString()
–我不会详细说明什么时候和为什么,但是你需要这样做(好的,只是提醒一下–总是一起实现hashCode和equals,如果你要在hashmap或arraylist中查找给定类的对象,你很可能需要实现这些方法)。你有很多选择去做:
- 手动实现这些方法——这对于toString()来说还可以,但对于
hashCode()
和equals(..)
。除非您非常确定您想要一个定制的、考虑周全的散列函数,否则您应该依赖另一种更实用的机制 - 使用IDE——所有IDE都可以生成这三种方法,要求您指定它们所基于的字段。哈希函数通常已经足够好了,剩下的就是让你免去编写样板比较、if和elses的麻烦。但是当您添加一个字段时,您不应该忘记重新生成方法。
- commons-lang–里,帮助你快速地写方法,或者用手工
append(field).append(field)
,或反射,例如reflectionEquals(..)
。再次添加字段需要修改,并且很容易忘记这一点。 - 番石榴——与commons-lang非常相似,各有利弊。番石榴带有等于的帮助函数(..)和hashCode以及toString()的构建器——您仍然需要手动添加/比较您想要包含的每个字段。
- project lombok——它插入到编译器中,将一些注释转化为实际的实现,让您完全不用编写生物模板代码。例如,如果您于值对象)。您只需要在编译时类路径上放一个jar,它应该可以工作。
您应该使用其中的哪一个?我通常排除手动方法,以及guava和commons-lang——它们需