【发布时间】:2016-08-26 08:30:32
【问题描述】:
我有以下关系:
@Data
@EqualsAndHashCode(callSuper=true)
public class Room extends BasePersistable {
private static final long serialVersionUID = 1L;
@Column(nullable=false)
private String uid;
@Column(nullable=false)
private String name;
@Column(nullable=true)
private String fullName;
@Column(nullable=true, length=500)
private String description;
@Column(nullable=true)
private String homepage;
@Column(nullable=false)
private String owner;
@ManyToOne
@JsonIgnoreProperties({"repos", "members"})
private Organization organization;
和
@Data
@EqualsAndHashCode(callSuper=true)
@JsonInclude(content=Include.NON_NULL)
public class Organization extends BasePersistable {
private static final long serialVersionUID = -7119760968529447945L;
@Column(nullable=false)
@NotEmpty
private String name;
@Column(nullable=false, unique = true)
@NotNull
private Integer uid;
@Column
private String avatar;
@Column
private String blog;
@Column
private String company;
@Column(nullable=false)
@NotNull
private String login;
@Column(nullable=true)
private String location;
@OneToMany(mappedBy="organization")
@JsonIgnoreProperties({"users", "joined", "organization"})
private List<Room> repos = new ArrayList<>();
当我从特定用户加载房间时,我收到此错误:
java.lang.StackOverflowError: null
at com.inkdrop.app.domain.models.Organization.hashCode(Organization.java:29) ~[classes/:na]
at com.inkdrop.app.domain.models.Room.hashCode(Room.java:34) ~[classes/:na]
at java.util.AbstractList.hashCode(AbstractList.java:541) ~[na:1.8.0_51]
at java.util.Vector.hashCode(Vector.java:992) ~[na:1.8.0_51]
at org.eclipse.persistence.indirection.IndirectList.hashCode(IndirectList.java:504) ~[org.eclipse.persistence.core-2.6.1.jar:na]
at com.inkdrop.app.domain.models.Organization.hashCode(Organization.java:29) ~[classes/:na]
at com.inkdrop.app.domain.models.Room.hashCode(Room.java:34) ~[classes/:na]
at java.util.AbstractList.hashCode(AbstractList.java:541) ~[na:1.8.0_51]
at java.util.Vector.hashCode(Vector.java:992) ~[na:1.8.0_51]
at org.eclipse.persistence.indirection.IndirectList.hashCode(IndirectList.java:504) ~[org.eclipse.persistence.core-2.6.1.jar:na]
at com.inkdrop.app.domain.models.Organization.hashCode(Organization.java:29) ~[classes/:na]
at com.inkdrop.app.domain.models.Room.hashCode(Room.java:34) ~[classes/:na]
at java.util.AbstractList.hashCode(AbstractList.java:541) ~[na:1.8.0_51]
at java.util.Vector.hashCode(Vector.java:992) ~[na:1.8.0_51]
at org.eclipse.persistence.indirection.IndirectList.hashCode(IndirectList.java:504) ~[org.eclipse.persistence.core-2.6.1.jar:na]
at com.inkdrop.app.domain.models.Organization.hashCode(Organization.java:29) ~[classes/:na]
at com.inkdrop.app.domain.models.Room.hashCode(Room.java:34) ~[classes/:na]
....
我不确定问题是否与 Eclipselink 或 Lombok 制作的东西有关。
编辑:我注意到有时它确实有效(当我删除整个数据库时)
【问题讨论】:
-
由于这发生在 hashCode 调用中,请检查 hashCode 方法中的逻辑 - 它们似乎是递归的或遍历整个对象模型。您可能不想依赖在任何集合属性上调用 hashCode。
-
我正在使用lombok,所以我并不真正负责实施
-
无论如何,lombok 有一个选项可以从计算中排除某些字段,这就成功了!
标签: jpa eclipselink lombok